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PHP 7 + MySQL 5.6， 流 行 版 本 的 组 合 
提供 大 量 的 开发 示例 ， 让 你 看 得 懂 、 学 得 会 、 做 得 出 
将 最 实用 的 技巧 融入 到 每 个 案例 中 ， 教 你 快速 成 为 网 站 应 用 开发 高 手 
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内 容 简 介 


PHP 已 经 走 过 了 20 多 年 ， 目 前 最 新 版 本 是 PHP 7， 性 能 方面 得 到 了 大 幅度 的 提升 。 本 书 就 是 立足 于 最 
新 版 的 PHP 和 MySQL， 从 最 基础 的 语法 基础 开发 ， 让 没有 编程 基础 的 人 也 学 会 PHP+MySQL 网 站 开发 。 

本 书 分 为 4 篇 共 19 章 , 第 一 篇 (1~6 章 ) 先 介绍 PHP 7 的 语法 和 一 些 新 特色 ; 第 二 篇 (7~10 章 ) 是 PHP 
的 一 些 高 级 应 用 ， 如 国际 化 、zip 文件 处 理 、 图 形 图 像 操作 、 正 则 表达 式 ; 第 三 篇 (11~15 章 ) 是 MySQL 数 
据 库 的 基础 入 门 ， 包括 数据 库 、 数 据 表 和 数据 的 常见 操作 ; 最 后 一 篇 (16~17 章 ) 是 PHP+MySQL 的 混合 操 
作 ， 还 包含 两 个 大 型 项 目的 开发 步骤 。 

本 书 适合 所 有 想 学 习 网 页 开发 、Web 项 目 开 发 的 入 门 读者 ， 也 适合 所 有 想 学 习 PHP 的 读者 ， 还 适合 做 
一 些 培训 机 构 的 PHP 和 MySQL 培训 教材 。 
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癌 。 言 


PHP 是 当前 开发 Web 应 用 系统 中 比较 理想 的 工具 ， 它 易于 使 用 、 功 能 强大 、 成 本 低廉 、 
安全 性 高 、 开 发 速度 快 且 执行 灵活 ， 应 用 非常 广泛 。 使 用 PHP+MySQL 开发 的 Web 项目， 在 
软件 方面 的 投资 成 本 较 低 、 运 行 稳 定 ， 因 此 现在 越 来 越 多 的 供应 商 、 用 户 和 企业 投资 者 日 益 认 
识 到 使 用 PHP 开发 的 各 种 商业 应 用 和 协作 构建 的 各 种 网 络 应 用 程序 ， 变 得 更 加 具有 竞争 力 ， 
更 加 吸引 客户 。 无 论 是 从 性 能 、 质 量 ， 还 是 价格 上 ，PHP+MySQL 都 成 为 企业 必须 考虑 的 开发 
组 合 。 

对 于 PHP+MySQL 应 用 开发 的 新 手 而 言 ， 本 书 不 失 为 一 本 好 的 入 门 教材 ， 使 用 了 最 新 版 
本 PHP 7， 又 从 最 基础 的 语法 入 手 ， 结 合 小 的 示例 ， 让 读者 能 够 学 完 就 会 。 


本 书 特点 


1. 以 代码 驱动 学 习 

每 章 都 配 有 与 本 章 知识 相关 的 小 示例 , 增加 读者 的 动手 能 力 , 用 代码 来 驱动 读者 一 步 步 学 
会 PHP。 

2. 基于 最 新 版 本 学 习 

全 书 采用 PHP 7+MySQL 5.6 的 最 新 版 本 搭配 ， 让 读者 学 习 前 沿 技术 ， 学 完 不 会 落伍 。 

3. 大 型 网 站 项 目 引 导 

本 书 最 后 两 个 案例 给 出 大 型 网 站 开发 的 完整 流程 , 从 数据 库 设 计 到 模块 分 析 到 最 终 每 个 模 
块 的 界面 设计 和 开发 ， 让 读者 了 解 PHP+MySQL 的 最 终 实 践 情况 和 如 何 去 实 践 。 

4. 零 基础 入 门 

本 书 是 一 本 完全 站 在 没有 PHP 语言 基础 的 读者 角度 写 的 书 , 全 书 将 PHP 语言 拆 分 成 一 个 
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个 小 的 技术 点 ， 让 读者 能 轻松 阅读 下 去 ， 而 且 能 够 轻松 学 得 会 。 

5. 配备 素材 ， 方 便 学 习 

为 了 方便 读者 学 习 , 本 书 配套 光盘 中 附带 了 所 有 案例 需要 的 源 文件 。 源 文件 为 读者 学 习 提 
供 了 参考 ， 同 时 用 户 可 以 直接 按照 书 中 操作 步骤 的 讲解 进行 操作 ， 以 便 提高 学 习 效率 。 


阅读 指南 


全 书 内 容 包括 4 篇 19 章 。 

第 1 章 介绍 了 PHP 7 语言 的 一 些 新 特性 ， 首 先 让 读者 了 解 为 什么 需要 学 习 PHP， 而 且 得 
学 习 最 新 版 本 PHP 7; 然后 让 初学 者 学 习 搭 建 PHP 的 开发 环境 和 开发 工具 ， 最 后 通过 一 个 
HelloWorld 的 例子 让 读者 了 解 PHP 程序 如 何 开始 。 

第 2 章 介 绍 了 PHP 语言 的 基础 语法 , 这 也 是 学 习 一 门 语言 的 开发 的 基础 ,包括 了 标识 符 、 
变量 、 常 量 、 数 据 类 型 、 表 达 式 、 运 算 符 、 流 程控 制 、 函 数 。 

第 3 章 介 绍 了 PHP 操作 网 页 的 一 些 基 础 ， 这 是 动态 网 页 的 关键 ， 就 是 与 用 户 的 交互 ， 这 
些 交 互 包括 表单 处 理 、 表 单元 素 处 理 、Cookie、Session。 我 们 都 知道 网 页 操作 离 不 开 表单 ， 我 
们 所 看 到 的 网 页 中 的 文字 、 图 像 、 文 本 框 、 按 钮 ， 这 些 都 是 表单 ， 所 以 本 章 也 是 PHP 进行 网 
页 开发 的 基础 。 

第 4 章 介绍 了 PHP 中 的 字符 串 和 数组 ， 当 我 们 多 写 一 些 PHP 网 页 开发 代码 的 时 候 就 会 发 
现 ， 其 他 网 页 开发 中 很 多 的 代码 都 涉及 字符 串 的 操作 和 数组 的 操作 ， 在 PHP 中 ， 它 们 大 多 通 
过 函数 来 完成 。 

第 5 章 介 绍 了 PHP 中 的 日 期 和 时 间 ， 这 是 网 页 开发 很 常见 的 操作 ， 所 以 PHP 提供 了 大 量 
的 函数 ， 学 起 来 很 简单 ， 相 信 这 章 不 会 难 倒 读者 。 

第 6 章 介绍 了 文件 和 目录 的 操作 ,我们 经 常 操作 电脑 的 读者 在 操作 系统 中 的 各 种 操作 其 实 
就 是 对 文件 的 操作 ， 网 页 开发 中 也 经 常 需要 操作 文件 ， 本 章 就 介绍 了 用 PHP 打开 、 读 取 等 常 
见 的 文件 操作 。 

第 7 章 介 绍 了 国际 化 ， 其 实 读者 对 此 都 不 陌生 ， 我 们 看 到 很 多 国际 网 站 都 有 “选择 语言 
这 一 项 ， 甚 至 苹果 手机 中 也 有 这 一 项 。 我 们 选择 一 下 语言 ， 系 统 所 有 的 界面 都 会 变 为 中 文 ， 这 
就 是 介绍 国际 化 的 原因 。 相 信 读 者 看 完 本 章 就 明白 了 。 

第 8 章 介 绍 了 zip 文件 的 处 理 ， 网 站 上 的 文件 越 来 越 多 ,我 们 都 知道 网 盘 ， 网 盘 为 了 存储 
更 多 的 文件 ， 就 会 包含 一 些 压缩 文件 ， 本 章 就 介绍 了 如 何 用 PHP 操作 这 些 压 缩 文件 。 

第 9 章 介 绍 了 PHP 如 何 操作 图 形 图 像 ， 其 中 会 介绍 GD2 扩展 库 ， 不 仅 可 以 操作 已 经 存在 
的 图 片 ， 还 可 以 利用 这 个 库 来 创建 图 片 。 
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第 10 章 是 正则 表达 式 的 介绍 ， 不 管 哪 门 语言 ， 都 会 学 习 到 正则 表达 式 ， 它 是 文字 处 理 的 
关键 ，PHP 也 提供 了 一 些 这 方面 的 函数 。 本 章 不 仅 会 让 读者 认识 什么 是 正则 ， 也 会 学 到 如 何 
处 理 网 页 中 的 一 些 验证 方法 。 

第 11 章 开始 介绍 MySQL,， 本 章 站 在 入 门 读者 的 基础 上 ， 详 细 介绍 了 MySQL 的 安装 、 配 
置 、 启 动 、 登 录 ， 最 后 还 对 MySQL 安装 失败 的 常见 原因 进行 了 分 析 。 

第 12 章 是 数据 库 的 基本 操作 ， 包 括 创 建 数据 库 、 删 除数 据 库 、 学 习 数 据 库 存储 引擎 ， 还 
会 学 习 如 何 查看 MySQL 默认 的 存储 引擎 。 

第 13 章 是 数据 表 的 基本 操作 ， 包 括 创建 数据 表 、 查 看 数据 表 结 构 、 修 改 数据 表 、 删 除数 
据 库 表 ， 最 后 还 会 学 习 一 些 数据 表 操 作 的 常见 问题 。 

第 14 章 是 数据 的 基本 操作 ， 包 括 添加 数据 、 更 新 数据 、 删 除数 据 、 查 询 数 据 ， 最 后 还 会 
学 习 一 些 数据 操作 的 常见 问题 。 

第 15 章 是 数据 库 的 整体 操作 ， 为 了 保障 用 户 的 一 些 信 息 ， 我 们 都 知道 网 站 要 经 常 进行 备 
份 ， 这 类 备份 主要 就 是 数据 库 的 备份 ， 本 章 包 括 数据 备份 、 数 据 还 原 、 数 据 库 迁移 。 

第 16 章 介绍 了 PHP 操作 MySQL 的 最 基本 方式 ， 包 括 连接 和 关闭 数据 库 、 操 作 数据 库 、 
操作 数据 表 、 操 作 数据 。 

第 17 章 介绍 了 PHP 操作 MySQL 数据 库 的 另 一 种 方式 一 一 RedBeanPHP， 包括 它 的 下 载 、 
安装 、CRUD 操作 和 调试 。 

第 18 章 是 使 用 PHP+MySQL 构建 模拟 考试 系统 ， 利 用 这 个 项 目 ， 演 示 PHP 开发 Web 系 
统 的 整体 流程 。 

第 19 章 是 使 用 PHP+MySQL 构建 在 线 购物 网 站 ， 通 过 这 个 项 目 ， 让 读者 了 解 一 个 网 站 从 
开始 设计 到 实战 开发 的 整个 过 程 。 








读者 对 象 


本 书 内 容 由 浅 入 深 ， 适 用 于 下 列 读者 : 


从 事 动态 网 站 开发 人 员 

接受 PHP 培训 的 学 员 

Web 开发 爱好 者 

网 站 维护 及 管理 人 员 

初级 或 专业 的 网 站 开发 人 员 

大 中 专 院 校 的 教师 及 培训 中 心 的 讲师 
进行 毕业 设计 和 对 PHP 感 兴趣 的 学 生 

从 事 ASP 或 JSP 而 想 转 向 PHP 开发 的 程序 员 
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光盘 内 容 


本 书 配套 光盘 内 容 包 括 示例 源 代 码 、 课 件 、 教 学 视频 。 
如 果 光 盘 有 问题 ， 请 联系 booksaga@163.com， 邮 件 主题 为 “PHP+MySQL 从 零 开 始 学 ”。 
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在 开始 学 习 PHP 之 前 ， 我 们 先 花 一 点 时 间 认 识 了 解 一 下 PHP， 并 介绍 一 下 划时代 的 新 版 本 
PHP 7 的 最 新 功能 。 

首先 ， 引 用 一 段 来 自 PHP 官方 网 站 php.net 对 于 PHP 的 介绍 : 

PHP， 即 “PHP: Hypertext Preprocessor”， 是 一 种 被 广泛 应 用 的 开源 通用 脚本 语言 ， 尤 其 
适用 于 Web 开发 并 可 戏 入 HTML 中 去 。 它 的 语法 利用 了 C、Java 和 Perl， 易 于 学 习 。 该 语言 的 
主要 目标 是 允许 Web 开发 人 员 快速 编写 动态 生成 的 Web 页 面 ， 但 PHP 的 用 途 远 不 止 于 此 。 

从 这 段 话 中 我 们 可 以 明白 ，PHP 语言 最 适合 的 项 目 是 Web 开发 ， 这 也 是 本 书 的 写作 目的 ， 
通过 阅读 本 书 ， 读 者 可 以 快速 地 掌握 PHP 语言 ， 了 解 MySQL 数据 库 基础 知识 ， 灵 活 使 用 各 种 
开发 工具 进行 Web 项 目 开 发 。 


下 .1 pHp 的 发 展 历程 


了 解 一 门 语言 ， 我 们 必须 知道 这 门 语言 的 发 展 史 ， 本 书 通过 版 本 的 变化 以 时 间 轴 的 形式 来 说 
明 PHP 的 发 展 历程 。 

1. 1995 年 初 PHP 1.0 诞生 

Rasmus Lerdof 发 明了 PHP， 这 是 简单 的 一 套 Perl 脚本 ， 用 来 跟踪 访问 者 的 信息 。 这 个 时 候 
的 PHP 只 是 一 个 小 工具 而 已 ， 它 的 名 字 叫 做 “Personal Home Page Tool” (个 人 主页 小 工具 〉。 

2. 1995 年 6 月 PHP 2.0 诞生 


Rasmus Lerdof 用 C 语言 来 重新 开发 这 个 工具 ， 取 代 了 最 初 的 Perl 程序 。 这 个 新 的 用 C 写 的 
工具 最 大 的 特色 就 是 可 以 访问 数据 库 ， 可 以 让 用 户 简单 地 开发 动态 Web 程序 了 。 这 个 用 C 写 的 
工具 又 称 为 PHP/FI。 它 已 经 有 了 今天 PHP 的 一 些 基 本 功能 了 。 


3. 1998 年 6 月 PHP 3.0 诞 生 


虽然 说 1998 年 6 月 才 正式 发 布 PHP 3.0， 但 是 在 正式 发 布 之 前 ， 已 经 经 过 了 9 个 月 的 公开 
测试 。 
Andi Gutmans 和 Zeev Suraski 加 入 了 PHP 开发 项 目 组 。 这 是 两 个 以 色 列 工程 师 ， 他 们 在 使 
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用 PHP/FI 的 时 候 发 现 了 PHP 的 一 些 缺点 ， 然 后 决定 重 写 PHP 的 解析 器 。 








总 在 这 个 时 候 ，PHP 就 不 再 称 为 Personal Home Page 了 ， 而 改称 为 PHP : Hypertext 
[ Preprocessor。 

















PHP 3.0 是 最 像 现 在 使 用 的 PHP 的 第 一 个 版 本 ， 这 个 重 写 的 解释 器 也 是 后 来 Zend 的 雏形 。 
PHP 3.0 的 最 强大 的 功能 就 是 它 的 可 扩展 性 。 它 除 提供 给 第 三 方 开发 者 数据 库 、 协 议和 API 的 基 
础 结构 之 外 ， 还 吸引 了 大 量 的 开发 人 员 加 入 并 提交 新 的 模块 。 


4. 2000 年 5 月 PHP 4.0 发 布 


Andi Gutmans 和 Zeev Suranski 在 4.0 做 的 最 大 的 动作 就 是 重 写 了 PHP 的 代码 ， 发 明了 Zend 
引擎 来 增强 程序 运行 时 的 性 能 和 PHP 的 模块 性 。 这 个 Zend 实际 上 就 是 Andi 和 Zeev 名 字 缩 写 的 
合 称 。 

使 用 了 Zend 引擎 ，PHP 除 获得 更 高 的 性 能 之 外 ， 也 有 其 他 一 些 关键 的 功能 ， 包 括 支持 更 多 
的 Web 服务 器 、HTTP Session 的 支持 、 输 出 缓冲 等 。 


5. 2004 年 7 月 PHP 5.0 发 布 


PHP 5.0 的 核心 是 Zend 引擎 2 代 。 它 引入 了 新 的 对 象 模 型 和 大 量 的 新 功能 ， 比 如 引入 了 
PDO (PHP Data Object) 。 


6.2015 年 12 月 PHP7.0 发 布 


使 用 PHPNG 引擎 ， 大 幅 提高 了 性 能 ， 引 入 了 标量 类 型 声明 、 返 回 值 类 型 声明 、 匿 名 类 等 一 
些 期 竺 已 久 的 新 特性 。 








二 有 读者 可 能 会 问 PHP 6 到 哪里 去 了 ? 说 来 有 趣 ，PHP 的 开发 者 们 原来 计划 有 PHP 6， 可 是 做 
着 做 着 把 原先 PHP 6 计划 的 特性 在 PHP 5.5、5.6 版 实现 了 ， 后 来 大 伙 一 商量 算 了 ， 直 接 跨 
过 PHP 6 进入 PHP 7 时 代 了 。 现 在 许多 Linux 服务 器 使 用 的 还 是 PHP 5.3/54， 估 计 升级 到 
| PHP 7 还 需要 两 年 以 上 。 











1 .2 PHP 语言 的 优 缺 点 


笔者 认为 使 用 PHP 有 几 个 好 处 : 


@ ”开发 速度 快 ， 成 本 低 : 因为 PHP 语言 比较 简单 ， 大 多 数 你 需要 的 功能 都 有 扩展 库 或 类 
库 提 供 。 

@ 部 署 方便 、 便 宜 : PHP 是 跨 平台 的 脚本 语言 ， 在 Linux 服务 器 上 部 署 特别 方便 ， 而 且 
PHP 是 开源 免费 的 。 
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@@ ”适合 小 项 目 : 在 全 民 创 业 的 今天 ， 大 量 的 初创 企业 需要 进行 网 站 、 微 信 公 众 号 、 手 机 
客户 端 服务 器 API 的 开发 ， 许 多 开发 团队 不 超过 5 人 ，PHP 特别 适合 这 样 的 小 团队 进 
行 快速 开发 部 署 上 线 。 

@ 网络 资 源 丰富 、 便 于 解决 问题 : 许多 问题 在 百度 上 搜索 一 下 就 解决 了 。 

@ ”许多 网 站 提供 的 API 都 提供 官方 的 PHP SDK， 例 如 微 信 公众 号 平台 ， 官 方 只 提供 了 
PHP 的 例子 。 


当然 ，PHP 也 有 缺点 : 

@ 运行 速度 比 不 上 C/C+H， 这 可 能 是 脚本 语言 的 通病 ， 然 而 PHP 7 部 分 地 解决 了 这 个 问 
题 ， 可 以 将 脚本 文件 编译 为 执行 速度 更 快 的 中 间 代码 。 

@ ”PHP 传承 自 C、Perl 等 传统 第 三 代 语 言 ， 面 向 对 象 的 特性 从 PHP 4 开始 才 出 现 ， 比 较 
初级 ， 不 像 Java、C# 等 语言 对 于 面向 对 象 的 特性 支持 得 那么 完善 。 

@@ PHP 主要 适用 于 Web 项 目 ， 对 于 其 他 类 型 的 项 目 (如 图 形 界面 ) 的 支持 较 弱 。 


每 个 编程 语言 都 有 自己 的 特点 和 使 用 环境 ，PHP 语言 就 是 为 Web 项 目 而 生 的 ， 如 果 读 者 想 
要 学 习 Web 项 目 开发 ，PHP 语言 肯定 是 最 佳 选 择 之 一 。 


] .二 谁 在 用 PHP 
其 实 应 该 问 的 是 谁 没有 用 PHP。 现 在 使 用 PHP 进行 Web 项 目 开 发 的 著名 公司 太 多 太 多 ， 比 
如 新 浪 微 博 、 微 信服 务 器 端 、 淘 宝 /天 猫 、 百 度 等 都 在 大 量 地 使 用 PHP 开发 各 种 项 目 ， 大 量 的 开 


源 项 目 也 使 用 PHP 开发 ， 最 著名 的 有 维基 百科 、 博 客 软件 Wordpress、 网 站 内 容 管理 系统 
Drupal/Joomla、 客 户 关 系 管理 系统 SugarCRM 等 。 


.和 pHp 7 的 新 特性 


在 本 书写 作 的 时 候 ，PHP 官方 推出 了 划时代 的 新 作品 PHP 7， 有 些 新 的 特性 在 这 里 简略 地 讲 





“下 


1.4.1 ”性 能 提高 


PHP 过 去 一 向 是 以 开发 效率 见长 ， 语 言 性 能 较 差 ， 不 过 普通 的 网 站 项 目 一 般 是 IO 密集 型 项 
目 ， 瓶 颈 在 MySQL 数据 库 上 ， 体 现 不 出 来 PHP 的 性 能 劣势 。 
在 PHP7 中 使 用 了 新 一 代 的 PHPNG 执行 引擎 ， 一 般 的 PHP 代码 执行 效率 可 以 提高 约 60%。 
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1.4.2 标量 类 型 声明 


PHP 7 中 的 函数 的 形 参 类 型 声明 可 以 是 标量 了 。 在 PHP 5 中 只 能 是 类 名 、 接 口 、array 或 者 
函数 /匿名 函数 ， 现 在 也 可 以 使 用 string、int、float 和 bool 了 ， 例 如 : 





1.4.3 ”返回 值 类 型 声明 


PHP 7 增加 了 对 返回 类 型 声明 的 支持 。 类 似 于 参数 类 型 声明 ， 返 回 类 型 声明 指明 了 函数 返 
回 值 的 类 型 。 可 用 的 类 型 与 参数 声明 中 可 用 的 类 型 相同 ， 例 如 : 





1.4.4 NULL 合并 运算 符 


由 于 日 常 使 用 中 存在 大 量 同时 使 用 三 元 表达 式 和 issetO) 的 情况 ，NULL 合并 运算 符 使 得 变量 
存在 且 值 不 为 NULL， 它 就 会 返回 自身 的 值 ， 否 则 返回 它 的 第 二 个 操作 数 ， 例 如 : 





1.4.5 ”太空 船 操作 符 〈 组 合 比较 符 ) 


太空 船 操 作 符 用 于 比较 两 个 表达 式 。 当 $a 小 于 、 等 于 或 大 于 $b 时 ， 它 分 别 返 回 -1、0 或 1。 
比较 的 原则 是 沿用 PHP 的 常规 比较 规则 进行 的 ， 例 如 : 





EE 





1.4.6 ”匿名 类 


现在 支持 通过 new class 来 实例 化 一 个 匿名 类 ， 这 可 以 用 来 蔡 代 一 些 “ 用 后 即 焚 ” 的 完整 类 
定义 ， 例 如 : 





1.4.7 use 加 强 
从 同一 namespace 导入 的 类 、 函 数 和 常量 现在 可 以 通过 单个 use 语句 一 次 性 导入 了 ， 例 如 : 





PHP 7 还 在 持续 开发 中 ， 会 有 更 多 的 新 特性 出 现 。 有 兴趣 的 读者 可 以 阅读 一 下 官方 的 文档 ， 
下 载 源 代码 自行 编译 一 下 。 


下 旺 ” 描 建 PHP 开发 环境 


在 学 习 PHP 语言 之 前 ， 我 们 先 要 建立 起 开发 环境 。 由 于 有 大 量 的 PHP 开发 者 ， 所 以 现在 建 


a 
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立 开 发 环境 已 经 变 得 越 来 越 简单 了 。 本 章 带 领 读者 安装 XAMPP 开发 环境 ， 并 开发 一 个 最 简单 的 
PHP 程序 。 


1.5.1 下 载 XAMPP 


XAMPP 是 最 流行 的 PHP 开发 环境 ， 完 全 免费 并 且 支 持 Windows、Linux 和 OS X。 它 内 置 
了 所 有 我 们 进行 开发 PHP 需要 的 服务 器 端 软件 ， 包 括 〈 但 并 不 限于 ) : Apache、PHP、MySQL、 
PHPMyAdmin、 FileZillaFTP、MercuryMail、Tomcat、Perl、Webalizer 等 。 

XAMPP 这 几 个 字母 代表 的 是 : 


X: 操作 系统 Windows、Linux、OS X。 

A: Apache Web 服务 器 。 

M: MySQL 数据 库 服务 器 ， 安 装 的 其 实 是 MariaDB 数据 库 服务 器 ， 与 MySQL 完全 兼容 。 
P: PHP。 

P: Per。 


读者 可 以 在 https://www.apachefriends.org/zh_cn/download.html 进行 下 载 ， 本 书 所 有 例子 使 用 
PHP 7.0.1 测试 通过 ， 所 以 请 读者 下 载 PHP 7.0.1 及 以 上 版 本 的 XAMPP。 

笔者 在 这 里 留 一 个 截屏 〈 见 图 1.1) 用 来 记录 一 下 历史 ，PHP 的 开发 速度 非常 之 快 ， 读 者 下 
载 安装 的 时 候 很 有 可 能 已 经 不 是 这 个 版 本 了 ， 但 是 应 该 还 是 PHP 7.x。 


= 


(Oe ene cs leoesxyear-c aeegea- 避 三 





[= 
XAMPP 是 一 个 居于 9Apeche 发 生 本 ,天 中 得 全 MaraDB、PHPIDPe 仅仅 二 下载 
并 启动 和 入， 部 这 么 靖 闻 文档 常见 辐 是 
区 ET 有 关于 XAMPF 的 正式 史明 必 
芭 于 册 扫 站 DS 生 了 党 见 PE 开 
时 XAMPP for Windows 5.5.30, 5.6.15 & 7.0.1 了 的 襄 有 文档 有 秋 作 解决 g9 问 题 但 


Stack Overtow。 





Add-ons and Themes 


YH 





A XAMPP for Linux 5.5.30, 56.15&70.1 

Bitnamile 供 一 个 各 和 的 生 用 县 .用 
于 EXAMPP 上 安 关 Drupal、Joomlal, 
有 Was 好 WordPress 和 开间 多 流行 他 开 应 














1.1 PHP 的 当前 下 载 版 本 


安装 XAMPP 相当 简单 ， 相 信 大 多 数 读者 可 以 自行 安装 XAMPP， 笔 者 这 里 不 提供 没有 必要 
的 截图 了 ， 仅 对 于 可 能 会 遇 到 的 问题 进行 一 下 说 明 。 
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1.5.2 ”Windows 版 本 


下 载 Windows 安装 包 地 址 : http://sourceforge.net/projects/xampp/files/XAMPP%20Windows/， 
进入 对 应 版 本 的 目录 (本 书写 作 的 时 候 最 新 版 本 是 7.0.1) ， 有 两 种 安装 包 ， 我 们 分 别 介绍 。 


1. xampp-win32-5.6.15-1-VC11-installer.exe 
这 个 是 可 执行 文件 ， 执 行 即 可 ， 安 装 过 程 比较 简单 。 
(1) 打开 后 出 现 如 图 1.2 所 示 界面 ， 直 接 单 击 Next 按钮 。 


日 setup 一 口 





Setup - XAMPP 


人 


binami 





< Beck Next> Cancel 








图 1.2 开始 安装 界面 


(2) 出 现 如 图 1.3 所 示 界 面 ， 选 择 需 要 安装 的 插件 。 请 读者 根据 自己 的 需要 选择 。 学 习 本 
书 必须 安装 Apache、MySQL、PHP、phpMyAdmin。 





目 setup = BB Xx 
Select Components 
Select the components you want to instal; dear the components you do not want to instal, Cick 
Next when you are ready to continue. 








XAMPP Instaler 





<Bak || Next> | | Cancel 





1.3 选择 插件 
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(3) 出 现 如 图 1.4 所 示 界 面 ， 选 择 安装 路 径 。 建 议 安装 到 cxxampp， 但 是 安装 到 其 他 盘 也 
没 问题 ， 例 如 d:xampp、e:Xampp7。 





回 setup 






































Bed Next> | | Concel 














图 1.4 安装 路 径 
接 下 来 的 步骤 没有 什么 营养 ， 就 不 浪费 读者 的 时 间 了 。 
2. xampp-win32-7.0.1-0-VC14.zip 
这 个 是 压缩 文件 ， 直 接 解压 缩 到 c:xampp 目录 即 可 。 


如 果 安 装 到 其 他 目录 ( 非 c\xampp) ， 需 要 运行 一 下 setup_xampp.bat， 这 个 程序 会 更 新 配置 
文件 ， 只 需要 执行 一 次 即 可 。 





运行 一 下 test_php.bat ， 这 个 程序 会 测试 系统 是 否 安装 了 需要 的 软件 。 
例如 : 





就 是 系统 没有 安装 Microsoft Visual C++ 2015 运行 时 组 件 。 信 息 中 提供 了 下 载 地 址 。 
下 载 安 装 后 此 错误 就 消失 了 。 








本 元 | 请 读者 根据 自己 的 实际 情况 选择 ， 操 充 要 求 为 Windows Server 2008、Windows SEN 

| 2012、Windows Vista、Windows 7、Windows 8、Windows 10 等 。 如 果 需 要 安装 到 Windows 
XP， 则 要 下 载 XAMPP 1.82 版 ， 其 中 的 PHP 版 本 为 55， 本 书 的 一 些 例子 会 有 语法 方面 的 
问题， 请 读者 自行 修改 运行 






1.5.3 Linux 版 本 


下 载 Linux 安装 包 地 址 : http://sourceforge.net/projects/xampp/files/XAMPP%20Linux/， 进 入 对 
应 版 本 的 目录 ， 有 针对 64 位 CPU 和 x86 的 两 个 文件 。 读 者 可 以 在 Linux 命令 行 运行 uname 命 
令 判断 自己 的 Linux 版 本 并 选择 下 载 ， 例 如 : 





$ uname -a 

Linux ip-172-31-22-79 3.13.0-74-generic #118-Ubuntu SMP Thu Dec 17 
22:52:10 UTC 2015 x86 64 x86 64 x86 64 GNU/Linux 

# 笔 者 使 用 的 是 64 位 Linux 


下 载 文件 后 将 下 载 的 文件 设置 为 可 执行 文件 ， 然 





运行 安装 : 

$ chmod a+x xampp-linux-x64-7.0.1-0-installer.run 

$ sudo ./xampp-linux-x64-7.0.1-0-installer.run 
Welcome to the XAMPP Setup Wizard 


the componen 
1. Click 
XAMPP Core Files 


XAMPP Developer Files 


Is the selection above 


XAMPP on your compute' 


5 XAMPP on your computer 


166s% 





此 时 ，XAMPP 安装 到 /opylampp 目录 。 
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1.5.4 MAC OS X 版 本 


MAC OSX 版 本 的 下 载 地 址 : http://sourceforge.net/projects/xampp/files/XAMPP%%20Mac%20OS% 
20X/7.0.1/， 打 开 DMG 文件 ， 双 击 XAMPP 图 片 进 行 安装 。 安 装 路 径 : /Applications/XAMPP， 
这 里 不 再 给 出 图 示 了 ， 大 多 用 MAC OS X 的 读者 都 能 很 好 地 安装 。 


1.5.5 ”其 他 安装 方式 


由 于 网 络 方面 的 原因 ， 有 些 读者 可 能 无 法 下 载 XAMPP 官方 版 本 ， 那 么 另 一 个 方法 是 访问 
http:/xampps.com 下 载 由 phpStudy 提供 的 一 个 精简 版 。 

也 可 以 安装 http://www.phpstudy.net 提供 的 PHP 开发 环境 ， 网 站 作者 已 经 提供 了 非常 详细 的 
安装 与 使 用 说 明 ， 笔 者 就 不 再 重复 了 。 


1〗.6 ”配置 和 启动 XAMPP 


安装 好 后 ， 我 们 就 准备 使 用 XAMPP 了 ， 不 同 版 本 启用 方式 略 有 不 同 ， 这 里 简单 介绍 。 


1.6.1 Windows 版 本 
在 cixampp 目录 中 ， 找 到 xampp-control.exe 并 运行 ， 其 界面 如 图 1.5 所 示 。 


回 AMpp Control panel v322 [Cempiled Nov 12th 2015] - oO x 
XAMPP Control Penel v3.2.2 CE 
Tedues 
Sevice 。 Moue PIO(s) Pentls) Actons et 
pe oat 43 [son || Admn | | conto || ioos 画 se 
Wsal 224 2006 [Sp |[ Momm | | Conig || to ploer 
iezm sun | a | on | wn 豆 sevces 
i sr] We i i 
ee 5 ER om | [om] (oe 
i 






e] 。 
e] XANPP Apache ady rurming on port 443 
XAIPP MrSGL running on port 3306 
Starting Check-Tiner 
Cortrol Panel Ready 











1.5 XAMPP 控制 面板 
在 XAMPP 控制 面板 中 ， 可 以 启动 (Start) 、 停 止 (Stop) 、 管 理 (Admin) Apache 和 MySQL 
服务 器 进程 。 
(1) Config 按钮 可 以 使 用 编辑 器 打开 Apache、PHP、phpMyAdmin 的 配置 文件 ， 如 图 1.6 
所 示 。 也 可 以 用 文件 浏览 器 打开 Apache、PHP、phpMyAdmin 的 文件 目录 。 


10 


第 1 章 认识 PHP 7 





XAMPP Control pandv322 [Compile Nov 12th 2015] 
pi 


XAMPP Control Panel v3.2.2 

















PID(s) Portts) Actions 





站 js| 






































国 国 国电 








Module 

Apache 

MysoL 

Ticzie 

Merery 

Tomeat 
.41:22 [nain] Initializing Modules 
9.41 22 [Apache] XAIPP Apache is already runring on port 80 
9:4l:22 [Apache] 。 XAIPP Apache is already running en port 443 
9:41 22 [nysal] 。 XAIPP JIySQL is already ruming or port 3306 
.41:23 [nain] 
9:41:23 [nain] 
345 13 [nain] 
3-45.17 [nain] 


Starting Check-Tiner 
Cortrol Panel Ready 
Executing “c:\xanpp\” 
Executing“services.msc 














图 1.6 _ Config 按钮 


(2) Logs 按钮 可 以 用 编辑 器 打开 Log 文件 。 
(3) 右上 角 的 Config 按钮 可 以 配置 XAMPP 控制 面板 ， 如 图 1.7 所 示 。 





回 configuration of Control Panel 一 口 X 
Edtor: 

[Cppps publme sublme_text.exe 司 | 
Browser (empty = system default) 

















可 








Autostart of modules 
口 Apade 口 Fezla 口 Tomaat 


口 mwsQt DMerary 
Selected modules wii be started on next lunch of the 
Control panel. 


Dstart Control Panel Minmized 
回 Enable Tomcat output wndow 














[站 wweewedps | | iogoptons | 
X sbort 
图 1.7 配置 XAMPP 控制 面板 

















1.6.2 Linux 与 MAC OS X 版 本 


在 Linux 操作 系统 中 ，XAMPP 安装 到 /opylampp 目录 ， 在 MAC OS X 中 XAMPP 安装 到 
/Applications/XAMPP 目录 。 打 开 一 个 终端 (Terminal) ， 进 入 XAMPP 目录 ， 在 命令 行 执行 : 
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也 可 以 使 用 ctlscriptsh 来 启动 、 停 止 Apache 和 MySQL: 








第 MPHP 





1.6.3 查看 PHP 配置 信息 


首先 启动 Apache 服务 器 进程 ， 在 浏览 器 中 打开 : http://localhost/dashboard/phpinfo.php， 如 图 
1.8 所 示 ， 可 以 查看 PHP 的 详细 配置 信息 。 


新 手 务必 注意 ， 首 先 必须 打开 Apache 服务 器 进程 ， 否 则 上 述 链接 无 法 打开 。 启 动 进程 的 方 


式 就 是 打开 XAMPP 控制 面板 ， 单 击 Apache 后 面 的 Start 按钮 。 


井 图 | localhost/dashboard/phpntophp CC @ a 它 自 已 如 全 日 四 三 











| Wincows NTHIALCw IaD buid 10586 Windows IOiS86 



























































图 1.8 PHP 的 详细 配置 信息 
在 Windows 命令 行 执行 命令 查看 PHP 版 本 信息 : 


或 在 Linux、Mac OS X 终端 执行 命令 : 
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1 .7 第 一 个 PHP 程序 : Hello World 


这 是 个 学 习 编 程 语言 的 惯例 ， 就 是 当 学 习 一 门 新 的 编程 语言 的 时 候 ， 写 一 段 最 简单 的 代码 ， 
输出 Hello World! 


【示例 1-1】 第 一 个 PHP 程序 Hello World。 
我 们 有 两 个 办 法 可 以 做 到 : 


(1) 在 命令 行 上 直接 执行 如 下 命令 : 


(2) 用 任何 编辑 器 在 c:xampp\htdocs 目录 中 建立 一 个 文件 helloworld.php， 内 容 如 下 : 


用 浏览 器 打开 http://localhost/helloworld.php。 
如 果 能 够 看 到 Hello World! 那么 恭喜 ， 你 已 经 迈 出 了 学 习 PHP 语言 的 第 0 步 : 完成 了 Hello 
World 程序 。 


PHP 的 开发 工具 


工 欲 善 其 事 ， 必 先 利 其 器 。 学 习 PHP 语言 也 需要 称 手 的 工具 ， 最 重要 的 工具 就 是 编辑 器 
了 。 笔 者 推荐 Sublime Text 3 编辑 器 、Atom 编辑 器 、NetBeans 集成 开发 环境 ， 大 家 根据 自己 的 
具体 情况 可 以 自行 选择 一 款 合 适 的 编辑 器 。 

由 于 相关 的 软件 都 在 不 断 地 开发 升级 ， 笔 者 这 里 的 介绍 和 使 用 方法 可 能 会 过 时 ， 如 果 读 者 使 
用 了 新 的 版 本 ， 则 借鉴 一 下 即 可 。 





1.8.1 Sublime Text 简介 


Sublime Text 是 一 个 代码 编辑 器 ， 虽 然 是 收费 软件 ， 但 是 可 以 无 限期 免费 试用 。Sublime Text 
是 由 程序 员 Jon Skinner 开发 的 。Sublime Text 具有 高 效 简洁 的 用 户 界面 和 强大 的 功能 ， 例 如 代码 
缩 略 图 、Python 插件 等 ， 还 可 自 定 义 快 捷 键 、 菜 单 和 工具 栏 。Sublime Text 安装 简单 、 配 置 灵 
活 、 对 系统 要 求 极 低 ， 笔 者 经 常 使 用 一 个 8.9 英寸 的 Windows 平板 电脑 运行 Sublime Text。 

Sublime Text 的 主要 功能 包括 : 拼写 检查 、 书 签 、Python API、Goto 功能 、 项 目 管理 、 多 选 
择 、 多 窗口 等 。Sublime Text 是 一 个 跨 平 台 的 编辑 器 ， 支 持 Windows、Linux、Mac OS X 等 操作 
系统 。 

Sublime Text 最 强大 的 功能 是 支持 安装 插件 ， 绝 大 多 数 的 插件 是 免费 的 ， 这 给 了 Sublime 
Text 近乎 无 限 的 功能 扩展 。 

如 图 1.9 所 示 是 笔者 使 用 的 Sublime Text 编辑 器 截屏 。 





图 1.9 blime Text 编辑 器 


1. 下 载 安装 Sublime Text 3 
Sublime Text 3 下 载 地 址 为 http://www.sublimetext.com/3， 下 载 界面 如 图 1.10 所 示 。 
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虽然 Sublime Text 3 仍然 处 于 Beta 状态 ， 但 是 笔者 认为 它 已 经 非常 稳定 了 ， 功 能 方面 更 是 比 


Sublime Text 2 强大 了 许多 。 


官方 网 站 提供 了 各 个 操作 系统 的 安装 包 ， 请 读者 根据 自己 的 需要 下 载 安装 。 笔 者 比较 喜欢 安 


装 portable version 〈 绿 色 版 ) ， 仅 需 解压 缩 到 一 个 目录 即 可 使 用 ， 十 分 方便 。 





CEE 一 一 GCCOOOOOD 


Sublime Text 3 











图 1.10 Sublime Text3 下 载 界面 


2. 安装 Package Control 
Package Control 官方 网 站 : https://packagecontrol.io/ 


Package Control 是 Sublime Text 的 插件 管理 器 ， 包 含有 超过 2500 个 插件 。 对 于 使 用 Sublime 


Text 的 程序 员 ，Package Control 是 必须 安装 的 ， 因 为 功能 太 强 大 了 。 
访问 : https://packagecontrol.io/installation 


(1) 在 Sublime Text 3 编辑 器 中 打开 console (控制 台 ) ， 选 择 菜单 View 一 Show Console。 


(2) 将 页 面 上 的 Python 脚本 复制 粘贴 到 console， 按 回 车 键 。 
Package Control 安装 完成 后 会 提示 : 


这 个 时 候 重 新 启动 sublime。 选 择 菜单 Preferences 一 Package Control， 可 以 看 到 Package 


Control 安装 好 了 ， 如 图 1.11 所 示 。 


3. 安装 插件 

安装 好 Package Control 以 后 ， 可 以 安装 插件 了 。 首 先 我 们 来 安装 中 文 语 言 包 ， 毕 竟 

下 面 以 Windows 版 为 例 安装 插件 。 
(1) 选择 菜单 Preferences 一 Package Contrl ， 在 弹出 窗口 选 

Package， 当 我 们 输入 前 半 部 分 时 ， 会 有 自动 提示 ， 如 图 1.12 所 示 。 


发 环境 可 以 节约 


量 untiled - Sublime Tet (UNREGISTERED) 


Ele Edit Selection Find View Goto Iools Project | Preferences Help 


Package co 可 


Browse Packages.. 
Settings — Default 
Settings — User 
Settings — More 

Key Bindings — Default 
Key Bindings ~ User 
Font 

Color Scheme 


Package Settings 


Package Control 


Package Control: R 


Package Control: 
Package Control: 


Package Control: Upg 


Package Control: 
Package Control: 


图 1.11 


-点 时 间 。 





Package Control 安装 完成 











文 开 


择 Package Control: Install 





量 untitled - Sublime Text (UNREGISTERED) 


Eile Edit Selection Find View Goto 


Package Control | 


Package Contr 


Package Control: 
Package Control: 
Package Control: 
Package Control: 
Package Control: 
Package Control: 


Package Control: 


Package Control: 


Tools Project Preferences Help 


Package Control: R 


Package Control: 
Package Control: 


Package Control: 


Package Control: C 


Tinet coumn1 





图 1.12 选择 Package Control 


Plain Text 
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(2) 在 弹出 窗口 中 输入 chinese， 如 图 1.13 所 示 。 


量 untitled - Sublime Tot (UNREGISTERED) 


Ele Edt Selection Find View Goto Tools 


Broject Preferences Help 





Sahei 





schemes created by Clay Schubi 


图 1.13 选择 语言 
(3) 单 击 ChineseLocalization 插件 ， 进 行 安装 。 安 装 完成 后 Sublime 菜单 就 变 成 中 文 了 ， 如 
图 1.14 所 示 。 
国 untiuled - Sublime Text (UNREGISTERED) 一 口 X 
荣 单 但 ” 编 疆 ”选择 ”查找 ”视图 | 转 到 (GO 工具 中 项目 oj， 首选 项 (帮助 








图 1.14 中 文 菜单 
(4) 下 面 安装 PHP 语法 检查 插件 ， 选 择 菜单 “首选 项 ”一 Package Control， 
Control: Install Package， 在 弹出 窗口 中 输入 sublimelinter， 如 图 1.15 所 示 。 


选择 Package 








硬 untited - Sublime Tet (UNREGISTERED) 
某 单 日， 疾 辣 日 


选择 @) 查找) 视图 W 转 到 (G6) 工具 中 项 目 四 


首选 项 (NM 帮助 (H) 


6.1; sublimelinter.com 


ET 


SublimeLinter. 


sublimeLinter plugin for 


图 1. 


(5) 安装 SublimeLinter 插件 后 ， 
所 示 。 











ffeescnpt using coffeelint 


interSublmetnter 


Plain Text 


15 选择 sublimelinter 


复 这 一 过 程 ， 再 安装 SublimeLinter-php 插件 ， 如 图 1.16 





硬 ntuled - Sublime Tet (UNREGISTERED) 
菜单 日 ”编辑 日 ”选择 9 


视 W 


转 到 (GO， 工具 (项目 p)， 首选 项 NI 帮助 (H) 


kublimelinter-php 


hp 


SublimeLinte' 
s plugint 


or PHP, using php + 


github.com/Sublimelinter/Sublmelinter-php 


SublimeLinter-php: 


图 1.16 





PlainTent 


选择 SublimeLinter-php 


(6) 安装 好 SublimeLinter 和 SublimeLinterphp 后 ， 还 需要 设置 一 下 环境 变量 ， 将 PHP 加 
到 PATH 环境 变量 中 ， 这 样 SublimeLinterphp 才能 正常 工作 。 


Windows 操作 系统 中 如 何 将 PHP 加 到 PATH 环境 变量 呢 ? 下 面 以 Windows 10 为 例 ， 进 行 讲 


述 : 


@ 打开 控制 面板 ， 找 到 “系统 ”。 





19 


PHP+MySQL 网 站 开发 从 零 开始 学 〈 视 频 教学 版 ) 


20 





@ 在 “系统 ”窗口 右 侧 找到 “高 级 系统 设置 ”。 

@ 在 弹出 窗口 右 下角 找 到 “环境 变量 ”。 

@ 在 “环境 变量 ”窗口 找到 系统 变量 Path， 单 击 “ 编 辑 ”按钮 。 

@ 在 “编辑 环境 变量 ”窗口 ， 单 击 “ 新 建 ” 按 钮 ， 输 入 c:xampp\php， 单 击 “ 确 定 ” 按 
钮 ， 如 图 1.17 所 示 。 























往 繁 环境 变 旦 x 
3%SystemRoot36\system32 新 建 ) 
%SystemRoot% 人 
%SystemRoot3%\System32\Wbem 综 生 ( 
%SYSTEMROOT%6\System32\WindowsPowerShellv1.0\ 
[eampp\php 浏览 B). 
CAProgram Files\Skype\Phone\ 

删除 (D) 
上 移 U) 
下 移 D 
编 音 文本 四 … 
| 











图 1.17 环境 变量 


@ 重新 启动 sublime。 


另外 还 可 以 安装 以 下 插件 : 

@ SideBarEnhancements: 在 侧 边 栏 增加 一 些 实用 功能 。 

@ BracketHighlighter: 用 于 高 亮 显示 括号 匹配 。 

@  Git: 提供 方便 的 Git 版 本 控制 功能 。 

@ ConvertToUTF8: 文件 编码 插件 ， 可 以 编辑 、 转 码 GBK、UTF8 编码 的 文件 。 
4. 项 目 管理 功能 


对 于 Sublime 来 说 ， 项 目 就 是 文件 夹 ， 可 以 添加 多 个 文件 夹 到 左 侧 的 侧 边 栏 中 。 添 加 文件 夹 
c:xampp\htdocs 到 项 目 ， 如 图 1.18 所 示 。 
















量 Cxampp\htdocs\index.php (htdocs) - Sublime Text (UNREGISTERED) 





某 单 ”入 强 (5 运 深 (S) 查找 () 视 加 (V) 装 到 (G) 工具 m 【项目 加 IN) 天 动 H) 
N FILE 打开 项 目 (O).… 
Denrs 
TD ntdocs 
i 亿 过 切 近 项 目 (5).- Col+Ak+p 
这 二 ER 有 ER) > 
上 器 webalizer 另存 硕 目 为 (A) 
* 中 xampp 
applications nt 
国 banamicss 


国 tariconico 





于 存 为 (A)… 

四 maitestphp 

i 过 文件 夫 珊 目 (D) 
从 项 目 儿 除 所 有 文件 夫 (M) 
剧 新 文件 交 (E) 





图 1.18 添加 文件 夹 cxampp\htdocs 到 项 目 


5. 语法 高 亮 功 能 


Sublime 支持 询 


图 1.19 所 示 。 


Sublime 会 自动 判断 当前 文件 是 PHP 代码 文件 ， 并 对 PHP 语法 进行 高 亮 显 示 ， 方 便 查 看 。 





Cvampp\htdocs\index.php (htdocs) - Sublime Text (UNREGISTERED) - 0O x 


匡 单 昌 。” 状 强 (E) 远近 (5) 间 近 由 视 届 (V) DD 项目 (P) 首先 基 (N) 帮助 (H) 
NF 


TY 巴 ntdoc 
加 dashboard 
» Oimg 
六 webalzer 
关口 zampp 


faviconiico 


DD maitestphp 
testphp 





Tab Se 4 


图 1.19 语法 高 亮 (黑白 印 刷 效果 可 能 不 是 很 清楚 ) 





6. 输入 PHP 函数 智能 提示 功能 
在 打开 的 index.php 文件 头 部 <?php 之 后 新 建 一 行 ， 输 入 str， 如 图 1.20 所 示 。Sublime 自动 


[多 语言 的 语法 高 亮 。 打 开 cxampp\htdocsindex.php， 体 验 语法 高 亮 功能 ， 如 
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提示 了 7 个 函数 和 一 个 关键 字 ， 按 上 下 键 选择 或 用 鼠标 单 击 stremp，Sublime 会 自动 完成 
stremp()， 并 将 光标 放 在 0 中 间 便 于 输入 代码 。 





Cvampp\htdocs\indecphp «(htdocs) - Sublime Text (UNREGISTERED) = oO Xx 
本 单 但 ” 壬 雪上 运 尝 (5) 可 找 ) 装 到 (G) 工具 (D ”项目 P) 首先 项 (N) 


TE ntdocs 

上 DO dashooard 

上 口 mg 

上 器 webalizer 

上 中 mampp 
国 applications.html 
因 btnamicss 
加 taionico 


因 maitestphp 
因 testphp 








图 120 


7. 语法 检查 功能 

安装 了 SublimeLinter-php 插件 后 ， 会 自动 对 PHP 代码 进行 语法 检查 ， 例 如 : 在 打开 的 
index.php 中 输入 如 下 代码 : 

echo 'hello wor1ldl! ' 

输入 代码 后 的 效果 如 图 1.21 所 示 。Sublime 已 经 发 现 了 错误 ， 在 第 四 行 有 个 红 点 ， 在 最 下 方 
的 状态 栏 中 显示 了 错误 信息 : 不 对 啊 ? 怎么 是 论 应 该 是 ， 或 者 ， 哦 ， 原 来 忘记 写 了 。 


国 Campp\htdccs\index.php . (htdccs) - Sublime Text (UNREGISTERED) - 0O x 


菜单 (. 蝙 绢 (E) ” 远 皖 ($) 豆 找 由 视 届 (V) 转 到 (G) 工具 中 ”项目 (PB) 首先 项 N) 帮 动 时 ) 
N 





vB ntiocs 
yO dashboard 


webalizer 


BB maitestphp 
四 testphp 





Error unerpected TF MIA), expeding , or > line 4, CoumnT 


图 121 语法 检查 
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8. 执行 PHP 代码 
在 Sublime 编辑 器 中 也 可 以 直接 调用 PHP 解析 器 执行 当前 编辑 的 PHP 代码 文件 。 

















(1) 选择 菜单 “工具 ”一 “编译 系统 ”一 “新 编译 系统 ”， 如 图 1.22 所 示 。 





量 camppWtdocsvndexphp Idaca ie Tedt (UNREGISTERED) 
对 弟 虽 ”六 S 日 ”过 SG 坦 持 0 机 0 
PEN LE 全 人 三板 . 





图 122 选择 “新 编译 系统 ” 


(2) 在 新 建 的 文件 编辑 窗口 中 输入 如 下 内 容 : 


"cmd": ["C:\\xampp\\php\\php.exe", "$file"], 
"file regex": "php$", 
aelector": "source .php" 

} 


这 些 内 容 是 JSON 格式 的 配置 信息 ，Sublime 配置 文件 的 格式 都 是 JSON 格式 。 如 果 读 者 安 
装 的 XAMPP 不 在 c:xampp 中 ， 则 需要 修改 第 二 行 的 c:\xampp， 改 为 读者 安装 的 目录 即 可 。 
保存 这 个 文件 ， 保 存 文件 名 为 php.sublime-build。 






(3) 新 建 一 个 PHP 代码 文件 : 
选择 菜单 “菜单 ”一 “新 建文 件 ”， 在 新 建 的 untitle 编辑 窗口 输入 如 下 内 容 : 
<?php 


echo 'hello world!'; 
i 





选择 菜单 “菜单 ”一 “保存 ”， 将 这 个 文件 命名 为 helloworld.php。 保 存 好 以 后 ， 选 择 菜 和 


“工具 ”一 “编译 ”。 
在 Sublime 编辑 器 的 下 方 出 现 一 个 子 窗口 显示 了 PHP 代码 的 运行 结果 ， 如 图 1.23 所 示 。 
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加 Cvampp\htdocs\helloworid.php (htdocs) - Sublime Text (UNREGISTERED) -器 x 
条 单 日 ” 帝 竺 日” 运 侠 (G)， 坦 持 员 ， 视 到 (WO， 转 到 (G)， 工具 中 项目 (P) 阁 先 项 (N) 帮助 (H) 














php.sublime-build 


vB ntaocs 
» Ddashboard 
四 mg 
上 webalizer 
» Dampp 
nantml 
ss 







DB maestphp 
四 testphp 





图 1.23 PHP 代码 的 运行 结果 


9. 常用 快捷 键 

要 提高 编程 效率 ， 就 要 减少 鼠标 的 使 用 频率 ， 尽 可 能 使 用 键盘 来 操作 编辑 器 的 功能 。 

大 多 数 常用 的 功能 sublime 编辑 器 都 提供 了 快捷 键 。 读 者 应 根据 自己 实际 使 用 情况 加 以 学 习 
和 记忆 ， 一 个 好 办 法 就 是 将 常用 快捷 键 打印 下 来 放 在 屏幕 旁边 ， 多 用 几 次 就 记 住 了 。 

下 表 总 结 了 一 些 常 用 的 快捷 键 : 


CtrlHTab: 按 文 件 浏览 过 的 顺序 ， 切 换 当 前 窗 
Ctrl+PageDown: 向 左 切换 当前 窗口 的 标签 页 。 
Ctrl+PageUp: 向 右 切换 当前 窗口 的 标签 页 。 
Ctrl+K+B: 开局 /关闭 侧 边栏 。 

F11: 全 屏 模 式 。 

ShifttF11: 免 打扰 模式 。 

Ctrl+F: 打开 底部 搜索 框 ， 查 找 关键 字 。 
Ctrl+F2: 设置 /取消 书签 。 

CtrlH/: 注释 整 行 ( 如 已 选择 内 容 ， 同 “Ctrl+Shiftt/” 效 果 ) 。 
Ctrl+ 标 左 键 : 可 以 同时 选择 要 编辑 的 多 处 文本 。 


口 的 标签 页 。 


其 实 Sublime 编辑 器 在 菜单 上 提供 了 快捷 键 的 说 明 ， 所 以 读者 也 可 以 参考 菜单 来 学 习 ， 如 图 
1.24 所 示 。 
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图 1.24 ”快捷 键 说 明 


1.8.2 Atom 简介 


Atom 是 一 款 开 源 的 代码 编辑 器 ， 由 Github 公司 开发 ， 官 方 网 站 http://atom.io 。 

它 的 功能 和 Sublime 类 似 ， 也 是 通过 插件 来 扩展 功能 。 虽 然 Atom 编辑 器 比较 新 ，2015 年 1 
月 才 宣 布 开 源 ， 但 因为 开发 者 是 大 名 易 易 的 Github 公司 ， 所 以 在 程序 员 当 中 引起 了 广泛 的 关 
注 ， 许 多 Sublime 插件 的 作者 都 将 自己 的 插件 移植 到 了 Atom 上 。 

1. 下 载 安装 Atom 


访问 Atom 编辑 器 官方 网 站 http://atom.io， 单 击 下 载 (Download) 按 钮 下 载 安装 包 ， 如 图 1.25 
所 示 。 





na 





癣 ATOM 


A hackable text editor 


for the 21st Century 





| EE 


图 1.25 Atom 下 载 地 址 








Windows 版 本 支持 Windows 7 /8/10， 在 Windows 上 安装 Atom 非常 简单 
动 启动 Atom， 如 图 1.26 所 示 。 





， 安 装 完成 后 会 自 
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图 1.26 Atom 界面 


2. 安装 重 件 
在 Atom 中 安装 插件 十 分 简单 ， 我 们 先 安装 汉化 插件 。 选 择 菜 单 File 一 Settings， 如 图 1.27 
所 示 。 








图 1.27 选择 菜单 





在 Settings 窗口 ， 单 击 Install 链接 ， 在 打开 的 Install Packages 页 面 中 输入 chinese， 按 回 车 键 
进行 搜索 ， 找 到 simplified-chinese-menu 插件 ， 单 击 Install 按钮 进行 安装 ， 如 图 1.28 所 示 。 
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图 1.28 ”安装 汉化 插件 
安装 完成 后 Atom 编辑 器 界面 就 汉化 了 。 


接 下 来 请 读者 安装 linterphp 和 script 插件 ，linter-php 插件 用 来 检查 PHP 代码 语法 错误 ， 


日 


script 插件 用 来 在 Atom 编辑 器 中 直接 执行 当前 PHP 代码 。 


3. PHP 语法 高 亮 显示 





使 用 Atom 编辑 器 打开 c:\xampp\htdocs\helloworld.php ， 可 以 注意 到 Atom 编辑 器 自动 识别 


了 了 PHP 代码 文件 ， 并 对 PHP 代码 进行 语法 高 亮 显 示 ， 如 图 1.29 所 示 。 





图 1.29 语法 高 亮 显示 


4. PHP 语法 检查 功能 
安装 了 linterphp 插件 后 ，Atom 编辑 器 会 自动 对 PHP 代码 进行 语法 检查 。 例 如 ， 在 打 玫 


F 的 





index.php 中 输入 如 下 代码 : 
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echo 'hello world!' 


此 时 ，Atom 编辑 器 发 现 了 一 个 语法 错误 ， 在 左 侧 显示 了 一 个 小 红 点 ， 如 图 1.30 所 示 。 





图 1.30 语法 检查 


5. 执行 PHP 代码 功能 

安装 script 插件 后 ，Atom 编辑 器 可 以 直接 执行 多 达 63 种 脚本 语言 。 然 而 有 个 小 小 的 问题 ， 
需要 在 命令 行 启动 Atom 编辑 器 才能 找到 正确 的 环境 变量 ， 从 而 执行 PHP 解析 器 ， 这 一 点 没有 
Sublime 方便 ， 也 可 以 修改 script 插件 的 源 代 码 来 解决 这 个 问题 。 

笔者 安装 的 script 插件 版 本 为 3.4.1， 笔 者 已 经 联系 了 script 插件 的 作者 ， 希 望 新 的 版 本 能 够 


解决 这 个 问题 。 

JE 让 : 在 命令 行 启动 Atom 编辑 器 

Windows 版 本 ，Atom 的 安装 目录 为 : 

C:\Users\ 用 户 名 \AppData\Local\atom 

在 命令 行 中 进入 这 一 目录 ， 笔 者 安装 的 是 版 本 1.4.1， 所 以 执行 以 下 命令 : 

C:\Users\ 用 户 名 \AppData\Local\atom>app-1.4.1\atom 

然后 建立 或 者 打开 helloworld.php 文件 ， 选 择 菜 单 “ 扩 展 ” 一 Script 一 Run Script， 如 图 1.31 
所 示 。 
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此 时 ， 就 会 调用 PHP 解析 器 执行 当前 的 PHP 代码 文件 ， 在 编辑 器 下 方 显 示 结 果 。 

: 修改 script 插 件 代码 ， 强 制 调用 PHP 解析 器 

在 Atom 编辑 器 中 ， 选 择 菜单 “文件 ”一 “设置 ”， 在 设置 窗口 中 单 击 按钮 ， 打 开 插 件 源 代 
码 目录 ， 在 左 侧 的 目录 树 中 找到 文件 .atom\packages\script\lib\grammars.coffee。 

修改 第 340 行 如 下 : 

command: "c:\\xampp\\php\\php.exe" 

如 图 1.32 所 示 ， 保 存 文件 后 重新 启动 Atom 编辑 器 ， 就 可 以 选择 菜单 “扩展 ”一 Script 一 
Run Script 执行 PHP 代码 了 。 











图 1.32 执行 代码 


6. 常用 快捷 键 
要 提高 编程 效率 ， 就 要 减少 鼠标 的 使 用 频率 ， 尽 可 能 使 用 键盘 来 操作 编辑 器 的 功能 。 
大 多 数 常用 的 功能 Atom 编辑 器 都 提供 了 快捷 键 ， 在 每 个 菜单 的 右 侧 用 浅 灰色 字体 显示 了 相 
应 的 快捷 键 。 
下 面 列举 一 些 常用 快捷 键 : 
cmd-t 或 cmd-p: 查找 文件 。 
cmd-b: 在 打开 的 文件 之 间 切 换 。 
cmd-\: 显示 或 隐藏 目录 树 。 
ctrl-0: 焦点 移 到 目录 树 。 
ctrl-shift-s: 保存 所 有 打开 的 文件 。 
cmd-shift-o: 打开 目录 。 
cmd-up: 移动 到 文件 开始 。 
cmd-down: 移动 到 文件 结 
ctrl-g: 移动 到 指定 行 。 
cmd-r: 在 方法 之 间 跳 转 。 
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cmd-F2: 在 本 行 增加 书签 。 

F2: 跳 到 当前 文件 的 下 一 条 书签 。 
shift-F2: 跳 到 当前 文件 的 上 一 条 书签 。 
ctrl-F2: 列 出 当前 工程 所 有 书签 。 


1.8.3 ”其 他 流行 的 集成 开发 环境 与 开发 工具 


笔者 根据 自己 的 经 验 为 读者 简单 介绍 了 Sublime 和 Atom 编辑 器 ， 这 两 个 编辑 器 的 优点 是 简 
洁 、 快 速 ， 通 过 插件 扩展 功能 ， 缺 点 是 并 不 是 专门 针对 PHP 的 工具 ， 而 是 通过 插件 来 支持 PHP 
的 开发 。 

也 有 专门 针对 的 PHP 开发 工具 ， 例 如 PHPStore 和 Zend Studio， 有 兴趣 的 读者 可 以 试用 一 
下 ， 这 两 款 开发 工具 是 专门 针对 PHP 的 集成 开发 环境 ， 是 商业 软件 ， 需 要 购买 。 

另外 两 个 值得 一 提 的 工具 是 Eclipse PDT 和 NetBeans IDE。 这 两 个 集成 开发 环境 是 使 用 Java 
语言 开发 的 集成 开发 环境 ， 主 要 支持 Java 的 开发 ， 也 通过 插件 支持 PHP 的 开发 。 由 于 运行 在 
Java 虚拟 机 上 ， 对 系统 硬件 较 高 。 

微软 的 Visual Studio Code 也 支持 编辑 PHP 代码 ， 另 外 还 有 无 数 的 文本 编辑 器 都 可 以 编辑 
PHP 代码 文件 ， 读 者 应 选择 最 适合 自己 /团队 的 开发 工具 ， 尽 可 能 提高 效率 。 
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本 章 开始 学 习 PHP 的 基础 语法 ， 包 括 PHP 的 变量 、 常 量 、 数 据 类 型 、 表 达 式 、 运 算 符 、 流 
程控 制 和 函数 。 通 过 本 章 的 学 习 ， 读 者 可 以 掌握 最 基础 的 PHP 知识 ， 读 懂 简 单 的 PHP 代码 ， 具 
备 基础 的 编程 能 力 。 

其 实 PHP 官方 网 站 php.net 上 已 经 有 很 好 的 中 文 文档 介绍 PHP 语法 了 ， 我 们 在 这 里 会 引用 

- 些 php.net 上 的 中 文 文档 ， 并 加 一 些 笔 者 的 注解 ， 尽 量 写 的 通俗 易 懂 ， 简 约 简单 。 


PHP 标识 符 


1. 首先 我 们 来 回答 一 个 问题 : PHP 程序 是 如 何 通过 互联 网 提供 服务 的 
在 一 个 Web 项 目 中 ， 最 主要 的 工作 就 是 输出 HTML。 最 终 用 户 使 用 浏览 器 访问 Web 项 目的 
网 址 ， 这 个 请 求 经 过 了 互联 网 的 解析 到 达 了 Web 项 目的 服务 器 ， 服 务 器 执行 PHP 程序 ， 获 得 了 
HTML， 通 过 互联 网 返回 给 最 终 用 户 的 电脑 ， 最 终 用 户 在 浏览 器 看 到 HTML。 
2. 那么 问题 来 了 : 服务 器 如 何 执行 PHP 程序 
个 PHP 程序 其 实 就 是 文本 文件 ， 服 务 器 调用 PHP 解析 器 读 取 PHP 文件 进行 解析 。 解 析 


出 来 的 结果 可 以 是 HTML， 也 可 以 是 任何 格式 的 文本 ， 甚 至 可 以 输出 图 片 、 音 乐 、 电 影 ， 以 及 
其 他 各 种 你 能 想到 的 格式 ! 

3. PHP 解析 器 是 如 何 运行 PHP 程序 文件 的 呢 

PHP 解析 器 非常 复杂 ， 是 好 多 人 一 起 用 C 语言 开发 的 ， 基 本 上 我 们 可 以 这 样 理解 : 当 PHP 
解析 器 解析 一 个 文件 时 ，PHP 会 寻找 起 始 和 结束 标记 ， 也 就 是 <?php 和 ?>， 这 告诉 PHP 开 
始 和 停止 解析 二 者 之 间 的 代码 。 任 何 起 始 和 结束 标记 之 外 的 部 分 都 会 被 PHP 解析 器 直接 输出 ， 
而 <?php 和 ?> 之 间 的 PHP 代码 则 由 解析 器 经 过 一 系列 复杂 的 编译 优化 运行 后 将 结果 输出 。 

好 了 ， 别 问 问 题 了 ， 来 点 干货 吧 : 


@ PHP 代码 必须 以 <?php 和 ?> 包括 起 来 。 

@ 可 以 使 用 <2= ?> 直接 输出 表达 式 的 值 。 

@ ”在 <?php 和 ?> 中 可 以 有 许多 行 代码 ， 每 行 代码 都 要 用 分 号 ;结束 ， 注 意 这 里 必须 是 英文 
的 分 号 ， 中 文 的 分 号 不 能 用 。 
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PHP 解析 器 会 忽略 空格 、TAB、 回 车 键 造成 的 空白 。 
使 用 /注释 一 行 代码 。 

也 可 以 用 # 注 释 一 行 代码 ， 和 // 是 一 样 的 。 

使 用 **/ 注释 多 行 代码 ， 要 确保 不 要 谈 套 /*#/。 


试图 注释 掉 一 大 块 代 码 时 很 容易 出 现 该 错误 。 不 推荐 使 用 /* 注释 多 行 代 码 ， 使 用 编辑 器 


可 以 快速 地 注释 反 注释 代码 段 。 





2.2 克昌 


通俗 地 讲 ， 编 程序 的 时 候 需要 把 有 用 的 信息 先 起 个 名 字 ， 存 起 来 ， 一 会 再 用 ， 也 可 以 修改 这 
个 有 名 字 的 信息 。 这 个 起 了 名 字 存 起 来 的 信息 就 是 变量 。 变 量 就 像 “ 小 强 ” 一 样 在 代码 中 无 处 不 
在 ， 每 只 “小 强 ”都 有 一 个 名 字 ， 可 以 是 中 文 ， 也 可 以 是 英文 。 


2.2.1 变量 名 称 
PHP 中 的 变量 用 一 个 美元 符号 后 面 跟 变 量 名 来 表示 ， 变 量 名 是 区 分 大 小 写 的 。 
【示例 2-1】PHP 变量 。 





一 个 有 效 的 变量 名 由 字母 或 者 下 划 线 开头 ， 后 面 跟 上 任意 数量 的 字母 、 数 字 ， 或 者 下 划 线 。 
以 下 是 有 效 的 变量 名 : 


以 下 是 无 效 的 变量 名 ， 它 们 都 不 是 字母 或 下 划 线 开头 的 : 


2.2.2 ”给 变量 赋值 
用 等 号 -就 可 以 给 变量 赋值 ， 例 如 : 
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也 可 以 把 一 个 变量 的 值 赋 给 另 一 个 变量 : 


变量 赋值 总 是 传 值 赋 值 。 那 也 就 是 说 ， 当 将 一 个 表达 式 的 值 赋予 一 个 变量 时 ， 整 个 原始 表达 
式 的 值 被 赋值 到 目标 变量 。 这 意味 着 ， 当 一 个 变量 的 值 赋予 另外 一 个 变量 时 ， 改 变 其 中 一 个 变量 
的 值 ， 将 不 会 影响 到 另外 一 个 变量 。 

通俗 地 解释 传 值 赋值 ， 小 明 肚子 里 装 了 苹果 ， 传 值 赋值 给 小 强 ， 小 强 肚 子 里 现在 是 苹果 了 ， 
后 来 小 明 吃 了 香 药 ， 可 是 小 强 肚 子 里 还 是 苹果 。 


【示例 2-2】 给 变量 赋值 。 


这 个 例子 可 以 看 出 来 $b= $a; 是 一 个 传 值 赋值 ， 当 $a 的 值 发 生 改 变 以 后 ，$b 还 是 保留 原来 的 
值 ， 没 有 跟着 发 生 改变 。 


2.2.3 引用 赋值 
还 有 一 种 赋值 方式 叫 引用 赋值 ， 将 一 个 & 符号 加 到 将 要 赋值 的 变量 前 就 是 引用 赋值 。 
【示例 2-3】 引 用 赋值 。 





通俗 地 解释 引用 赋值 ， 版 主 小 明 肚子 里 装 了 苹果 ， 传 值 赋值 给 小 强 ， 小 强 =& 小 明 ， 小 强 其 
实 是 小 明 的 马甲 ， 后 来 小 明 吃 了 香 燕 ， 小 强 马甲 肚子 里 当然 变 成 了 香 燕 ， 如 果 小 强 马甲 赋值 桥 
子 ， 那 么 小 明 呢 ? 对 了 ， 也 成 橘子 了 。 


2.2.4 变量 的 数据 类 型 


变量 的 类 型 通常 不 是 由 程序 员 设 定 的 ， 确 切 地 说 ， 是 由 PHP 解析 器 根据 该 变量 使 用 的 上 下 
文 在 运行 时 决定 的 ， 例 如 : 
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这 样 做 的 优点 是 编程 的 时 候 比 较 方便 ，PHP 解析 器 会 自动 决定 变量 的 类 型 并 做 出 相应 的 操 
作 ， 缺 点 是 有 些 从 强 类 型 语言 转 过 来 的 读者 可 能 会 不 适应 。 


2.2.5 ”可 变 变量 


这 是 个 有 趣 的 话题 ， 在 后 边 的 许多 地 方 都 会 用 到 可 变 变量 ， 在 这 里 我 们 只 是 简单 地 介绍 一 下 
概念 。 
可 变 变量 的 意思 是 : 一 个 变量 的 变量 名 可 以 动态 地 设置 和 使 用 。 


【示例 2-4】 可 变 变量 。 





$a=hello 是 把 hello 赋值 给 了 变量 $a， 那么 $$a 是 什么 ? 写成 这 样 可 能 容易 理解 些 ，${$a}。 
${$a} 就 是 一 个 名 字 是 $a 的 值 的 变量 。 那 就 是 Shello 了 。S$$a 就 是 变量 $hello，$hello 的 值 是 
"world'。 


可 变 变 量 的 用 处 很 多 ， 这 里 先 简单 讲 一 下 ， 将 来 用 到 的 时 候 还 会 深入 讲解 。 


2.3 党 和 


与 变量 不 同 ， 常 量 的 值 是 不 能 改变 的 。 常 量 的 名 称 要 求 也 和 变量 一 样 ， 合 法 的 常量 名 以 字母 
或 下 划 线 开始 ， 后 面 跟着 任何 字母 、 数 字 或 下 划 线 。 
2.3.1 声明 常量 

需要 用 define() 来 声明 常量 ， 例 如 : 


常量 名 是 一 个 大 写 的 字符 串 ， 值 可 以 是 数字 、 字 符 串 、 布 尔 等 标量 数据 类 型 。 
也 可 以 用 const 关键 字 定 义 常量 ， 例 如 : 
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常量 与 变量 不 同 


常量 和 变量 有 如 下 不 同 : 


2.3.3 


常量 前 面 没有 美元 符号 ($) 。 

常量 只 能 用 define() 函数 或 const 关键 字 定 义 ， 而 不 能 通过 赋值 语句 。 
常量 可 以 不 用 理会 变量 的 作用 域 而 在 任何 地 方 定义 和 访问 。 

常量 一 旦 定义 就 不 能 被 重新 定义 或 者 取消 定义 。 
常量 的 值 只 能 是 标量 。 


检查 某 常量 是 否 存在 


用 defined0 函 数 检测 常量 是 否 存 在 ， 例 如 : 


2.3.4 


内 置 常量 


PHP 解析 器 在 解析 PHP 代码 之 前 就 会 定义 一 些 常量 ， 这 些 已 经 定义 好 的 常量 叫做 内 置 党 
量 。 这 些 内 置 常量 可 以 在 代码 中 随时 使 用 ， 下 面 列 出 来 一 些 常用 的 内 置 常量 。 


_DIR _: 指向 当前 执行 的 PHP 程序 文件 所 在 的 目录 。 例 如 当前 执行 的 PHP 程序 文件 
为 /www/websitelindex.php，_DIR_ 等 于 /www/website'。 

_FILE_: 当前 执行 的 PHP 程序 文件 名 。 例 如 当前 执行 的 PHP 程序 文件 为 
/www/website/index.php，__FILE_ 等 于 /www/website/index.php。 

TRUE，FALSE: 用 于 布尔 类 型 的 常量 ， 分 别 表示 真 和 伪 。 

_LINE_: 当前 PHP 程序 的 行 数 ， 用 来 调试 代码 比较 方便 。 

PHP_VERSION: PHP 的 版 本 号 。 

PHP_OS: 操作 系统 名 称 。 


每 个 PHP 模块 还 会 定义 一 些 常量 ， 所 以 在 PHP 中 灵活 使 用 常量 是 非常 重要 的 ， 在 后 面 介 绍 
各 个 PHP 模块 的 章节 中 会 具体 介绍 其 中 定义 的 常量 。 
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2 .4 数据 尖 弄 


前 面 介绍 变量 的 时 候 提 过 变量 的 数据 类 型 是 PHP 解析 器 根据 上 下 文 自动 决定 的 ， 现 在 我 们 
来 简单 介绍 这 些 数据 类 型 。 


2.4.1 数据 类 型 简介 
PHP 支持 8 种 原始 数据 类 型 。 


1. 四 种 标量 类 型 
boolean ( 布尔 型 ) 
integer ( 整 型 ) 
float ( 浮 点 型 ， 也 称 作 double) 
string (字符 囊 ) 
2. 两 种 复合 类 型 

@ array (数组 ) 

@ object (对 象 ) 

3. 两 种 特殊 类 型 

@ resource (资源 ) 
@ NULL (无 类 型 ) 


PHP 的 变量 无 须 声明 类 型 ， 给 变量 赋值 的 时 候 就 会 决定 变量 的 数据 类 型 ， 或 者 说 ， 变 量 的 
数据 类 型 是 和 它 所 存储 的 数据 相关 ， 并 且 是 可 以 改变 的 ， 例 如 : 


2.4.2 布尔 型 (boolean) 


这 是 最 简单 的 类 型 。 一 个 boolean 的 值 只 能 是 True 或 False， 赋 值 时 无 须 区 分 大 小 写 ， 
Trmue、TRUE、true、tRUe 都 是 TRUE。 


【示例 2-5】 布 尔 型 举例 。 
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在 echo 输出 的 时 候 ，boolean 值 TRUE 被 转 为 1 了 ， 而 FALSE 则 什么 都 没有 输出 ， 是 个 空 
字符 串 。 

上 边 的 代码 调用 了 一 个 函数 gettype， 这 个 函数 可 以 获取 变量 的 类 型 ， 并 返回 字符 串 。 下 文 
会 介绍 变量 相关 的 函数 ， 咱 们 这 里 先 简单 提 一 下 。 

当 一 个 变量 的 值 转换 为 boolean 时 ， 以 下 值 被 认为 是 FALSE: 


@ 布尔 值 FALSE 本 身 。 

整 型 值 0 ( 零 ) 。 

浮 点 型 值 0.0 ( 零 ) 。 

空 字 符 串 ， 以 及 字符 串 "0"。 

不 包括 任何 元 素 的 数组 array()。 

特殊 类 型 NULL ( 包括 尚未 赋值 的 变量 ) 。 
从 空 标记 生成 的 SimpleXML 对 象 。 


所 有 其 他 值 都 被 认为 是 TRUE 〈 包 括 任何 资源 ) 。 


2.4.3 整 型 (integer) 


整 型 是 最 基本 的 数据 类 型 ， 一 个 integer 是 集合 {..…, -2, -1, 0, 1, 2, …} 中 的 一 个 数 。 

32 位 平台 的 整形 最 大 最 小 值 约 等 于 正 负 二 十 亿 ，64 位 平台 下 的 最 大 最 小 值 通常 是 大 约 正 负 
9E18。 整 型 值 可 以 使 用 十 进 制 、 十 六 进 制 、 八 进 制 或 二 进 制 表示 ， 前 面 可 以 加 上 可 选 的 符号 〈- 
或 者 +) ， 例 如 : 


如 果 给 定 的 一 个 数 超出 了 integer 的 范围 ， 将 会 被 解释 为 floaydouble。 同 样 如 果 执 行 的 运算 
结果 超出 了 integer 范围 ， 也 会 返回 oaydouble， 例 如 : 


可 以 使 用 (int)、(intengen) 将 值 强制 转换 为 整形 ， 也 可 以 使 用 函数 intval0 将 值 转换 为 整形 ， 例 如 : 


对 于 超过 了 整 型 范围 的 整数 ， 可 以 使 用 PHP 的 数学 扩展 模块 BC Math 和 GMP 来 进行 运 
算 ， 这 两 个 模块 都 是 用 字符 串 来 表示 整数 ， 可 以 不 受 32/64 位 操作 系统 的 限制 。 
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2.44 浮 点 型 (float) 
浮 点 型 ， 也 叫 浮 点 数 float) 、 双 精度 数 double) 或 实数 (real) ， 例 如 : 


浮 点 数 的 字 长 和 操作 系统 相关 ， 通 常 最 大 值 是 1.8e308， 并 具有 14 位 十 进 制 数字 的 精度 (64 
位 IEEE 格式 ) 。 

可 以 使 用 (float)、(double) 将 值 强制 转换 为 浮 点 型 ， 也 可 以 使 用 函数 floatval(0 将 值 转换 为 浮 点 
型 ， 例 如 : 


2.4.5 ”字符 串 (string) 


一 个 字符 串 string 就 是 由 一 系列 的 字符 组 成 ， 其 中 每 个 字符 等 同 于 一 个 字 节 。string 最 大 可 
以 达到 2GB。 

一 个 字符 串 可 以 用 4 种 方式 表达 ， 我 们 先 看 两 种 最 常用 的 : 

@ 单 引 号 : 'string'。 

@。 双 引号 : "string"。 


这 两 个 的 区 别 是 : 
(1) 用 双 引 号 定义 的 字符 串 其 中 变量 会 被 解析 ， 例 如 : 


(2) 如 果 字符 串 是 包围 在 双 引号 〈") 中 ，PHP 将 对 一 些 特殊 的 字符 进行 转 义 解析 ， 参 见 表 2.1。 
表 2.1 转 义 


字符 含义 

mn 换行 

Yr 回 车 

Yt 水 平 制 表 符 
\ 反 斜 线 

$ 
¥ 
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( 续 表 ) 


安生 


字符 含义 


以 十 六 进 制 方式 来 表达 的 字符 


以 八进制 方式 来 表达 的 字符 





字符 串 还 有 两 种 表达 方式 ，heredoc 和 nowdoc。 这 两 种 语法 结构 比较 类 似 ， 很 适合 嵌入 大 段 
的 文本 。 
heredoc 的 语法 结构 是 : 


nowdoc 的 语法 结构 是 : 


可 以 发 现 nowdoc 的 标识 符 EOT 是 用 单 引号 括 起 来 的 。 就 像 双 引号 和 单 引 号 的 区 别 一 样 ， 
heredoc 对 其 中 变量 解析 并 对 特殊 字符 转 义 ， 而 nowdoc 不 解析 也 不 转 义 。 


【示例 2-6】heredoc 例子 。 


【示例 2-7】nowdoc 例子 。 








结束 时 所 引用 的 标识 符 必 须 在 该 行 的 第 一 列 ， 而 且 ， 标 识 符 的 命名 也 要 像 其 他 标签 一 样 遵守 
PHP 的 规则 : 只 能 包含 字母 、 数 字 和 下 划 线 ， 并 且 必 须 以 字母 和 下 划 线 作为 开头 。 





字符 串 的 相关 函数 有 上 百 个 ， 在 这 里 我 们 就 不 详细 介绍 了 ， 会 有 一 章 专门 讲解 。 
字符 串 可 以 用 '" (点 ) 运算 符 连 接 起 来 ， 注 意 小 (加 号 ) 运算 符 没有 这 个 功能 ， 例 如 : 
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一 个 值 可 以 通过 在 其 前 面 加 上 (string) 或 用 strval0) 函 数 来 转变 成 字符 串 ， 例 如 : 


国 风 和 者 可 能 和 发现 即使 没有 (sting)， 这 个 例子 也 会 输出 11， 这 是 因为 PHP 自动 将 这 点 
数 转 换 为 字符 串 输 出 了 。 





2.4.6 数组 (array) 


PHP 中 的 数组 实际 上 是 一 个 有 序 映射 ， 通 俗 来 讲 就 是 有 编号 /名 称 的 一 堆 变 量 组 合 在 一 起 。 
在 这 里 我 们 只 简单 介绍 一 下 数组 的 定义 ， 有 一 章 专门 讲解 数组 的 用 法 。 
可 以 用 array0 语 言 结构 来 新 建 一 个 数组 ， 例 如 : 


数组 单元 可 以 通过 array[key] 或 array{key} 语 法 来 访问 ， 例 如 : 


数组 单元 可 以 通过 amray[key] 或 arrayfkey} 语 法 来 修改 和 添加 新 的 单元 ， 例 如 : 


如 果 $array[$key] 还 不 存在 ， 将 会 新 建 一 个 ， 例 如 : 


可 以 用 print r0 和 var_dump() 函 数 输出 数组 ， 例 如 : 


自 PHP 5.4 起 可 以 使 用 短 数组 定义 语法 ， 用 [] 蔡 代 array0 定 义 数组 ， 例 如 : 


2.4.7 对 象 (object) 


这 里 要 讲 一 点 点 面向 对 象 的 知识 。 先 理解 一 下 类 和 对 象 ， 通 俗 地 讲 ， 类 (class〉 是 个 蛋糕 模 
子 ， 对 象 objecb) 是 用 类 模子 做 出 来 的 蛋糕 ， 每 个 对 象 object) 蛋糕 做 的 时 候 可 以 设置 不 同 的 
属性 蛋糕 花色 ， 有 /无 糖 ) ， 每 个 对 象 蛋 糕 还 可 以 有 类 模子 定义 的 方法 〈 动 作 ， 比 如 加 奶油 ， 
加 果 着 什么 的 ) 。 

假如 现在 有 个 类 Cake， 那 么 我 们 要 做 一 个 蛋糕 的 话 必须 使 用 new 关键 字 ， 例 如 : 
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那么 变量 $mycake 现在 就 是 一 个 object 数据 类 型 了 。 它 可 以 有 Cake 类 定义 的 属性 和 方法 ， 

我 们 可 以 使 用 这 些 属性 和 方法 与 Smycake 进行 交互 操作 ， 最 终 吃 掉 它 。 

2.4.8 资源 (resource) 


资源 (resource) 是 一 种 特殊 变量 ， 保 存 了 到 外 部 资源 的 一 个 引用 。 资 源 是 通过 专门 的 函数 
来 建立 和 使 用 的 。 例 如 文件 资源 、 数 据 库 资源 等 。 
资源 类 型 通常 通过 相关 的 资源 函数 来 操作 使 用 ， 例 如 : 


上 面 例子 中 变量 Shandle 就 是 一 个 文件 资源 类 型 。 


2.4.9 无 类 型 (NULL) 


特殊 的 NULL 值 表 示 一 个 变量 没有 值 。NULL 类 型 唯一 可 能 的 值 就 是 NULL。 
在 下 列 情况 下 一 个 变量 被 认为 是 NULL: 


@ ”被 赋值 为 NULL。 
@ ”尚未 被 赋值 。 
@ ”被 Unset()。 


例如 : 


2.4.10 ”数据 类 型 相互 转换 
标量 数据 类 型 可 以 相互 转换 ， 在 PHP 中 ， 有 两 种 常见 的 转换 方式 ， 自 动 转换 和 强制 转换 。 
1. 自动 转换 


这 种 转换 方式 较为 简单 ， 在 需要 转换 的 变量 前 加 上 想 要 转换 的 类 型 名 称 即 可 ， 例 如 (float)、 
(int)、 (string)。 


2. 强制 转换 
使 用 settype 函数 强制 转换 变量 的 数据 类 型 ， 例 如 : 
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2 .5 表 兴 式 


在 PHP 中 ， 几 乎 所 写 的 任何 东西 都 是 一 个 表达 式 。 简 单 但 却 最 精确 的 定义 一 个 表达 式 的 方 
式 就 是 “任何 有 值 的 东西 ”。 

最 基本 的 表达 式 形式 是 常量 和 变量 。 赋 值 语句 就 是 一 个 表达 式 ， 例 如 : 

$a=5; 


PHP 是 一 种 面向 表达 式 的 语言 ， 从 这 一 方面 来 讲 几 乎 PHP 都 是 表达 式 。 

考虑 刚才 已 经 研究 过 的 例子 ，"$a = 5"。 很 显然 这 里 涉及 两 个 值 ， 整 型 常量 5 的 值 以 及 变量 
$a 的 值 ， 它 也 被 更 新 为 5。 但 是 事实 是 这 里 还 涉及 一 个 额外 的 值 ， 即 附 值 语句 本 身 的 值 。 

赋值 语句 本 身 求 值 为 被 赋 的 值 ， 即 5。 实 际 上 这 意味 着 "$a = 5"， 不 必 管 它 是 做 什么 的 ， 是 
-个 值 为 5 的 表达 式 。 因 而 ， 这 样 写 "$b = ($a = 5)" 和 这 样 写 "$a =5; $b=5" (分 号 标志 着 语句 的 结 
束 ) 是 一 样 的 。 因 为 赋值 操作 的 顺序 是 由 右 到 左 的 ， 也 可 以 这 么 写 "$b = $a=5"。 




















2 .6 运算 符 


“运算 符 是 可 以 通过 给 出 的 一 或 多 个 值 ( 用 编程 行 话 来 说 ， 表 达 式 ) 来 产生 另 一 个 值 〈 因 而 
整个 结构 成 为 一 个 表达 式 ) 的 东西 。” 这 人 句 话 看 起 来 很 复杂 ， 但 是 其 实 你 已 经 用 过 好 多 次 运算 符 
了 ， 最 常见 的 运算 符 就 是 赋值 运算 符 =。 

我 们 这 里 不 会 详细 讲解 运算 符 ， 仅 仅 是 把 运算 符 做 个 简单 的 列表 ， 便 于 读者 参考 。 读 者 在 后 
面 的 实际 项 目 中 会 逐渐 掌握 运算 符 ， 现 在 只 需要 快速 地 浏览 一 下 ， 有 个 印象 就 可 以 了 。 


2.6.1 算术 运算 符 
常见 的 算术 运算 符 我 们 经 常 看 到 ， 参 见 表 2.2。 
表 2.2 常见 的 算术 运算 符 

















二 





【示例 2-8】 算 术 运算 符 。 
<3php 
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2.6.2 ”字符 串 运 算 符 


使 用 字符 串 运 算 符 “.” 可 以 把 两 个 字符 串 连 接 起 来 变 成 一 个 字符 串 。 如 果 变 量 是 整 型 或 浮 
点 型 ， 字 符 串 运 算 符 也 会 把 它们 转换 成 字符 串 ， 例 如 : 


2.6.3 ”赋值 运算 符 


常见 的 赋值 运算 符 参见 表 2.3。 
表 2.3 ”赋值 运算 符 


赋值 运算 符 含义 


例如 : 





2.6.4 ”比较 运算 符 


比较 运算 符 用 来 比较 数据 的 大 小 ， 常 见 的 比较 运算 符 参见 表 2.4。 
表 2.4 ”比较 运算 符 
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( 续 表 ) 


大 于 等 于 
小 于 等 于 
精确 等 于 (类 型 和 值 都 相等 ) 


[= 和 | 
这 里 着 重 说 一 下 一 和 一 的 区 别 ， 例 如 : 














在 以 上 几 个 例子 中 将 一 蔡 换 为 -一 ， 结 果 都 是 不 相等 ， 因 为 $a 与 $b 的 类 型 不 同 ， 值 也 不 同 。 


fH 代码 的 时 代 ， 要 全 用 一 和! =， 因为 这 两 个 运算 特 人 自动 进行 类 型 转 掏 ， 有 时 候 ] 


” 会 带 来 意 想不到 的 麻烦 。 | 





2.6.5 ”逻辑 运算 符 
编程 自然 少不了 进行 逻辑 判断 和 运算 ， 所 以 逻辑 运算 符 的 含义 必须 弄 清楚 (参见 表 2.5) 。 
表 2.5 有 逻辑 运算 符 














其 中 逻辑 与 、 逻 辑 或 有 两 种 不 同形 式 运算 符 的 原因 是 它们 运算 的 优先 级 不 同 ，|| 比 OR 优先 
级 高 ，&& 比 AND 优先 级 高 。 
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2.6.6” 按 位 运算 符 
按 位 运算 符 ， 顾 名 思 义 就 是 按照 “位 ”的 单位 对 整数 进行 处 理 。 不 同 运算 符 的 含义 参见 表 2.6。 
表 2.6 按 位 运算 符 





2.6.7 ”错误 控制 运算 符 
错误 控制 运算 符 写 在 表达 式 的 前 面 ， 具 体 符号 是 @， 用 来 屏蔽 错误 信息 ， 例 如 : 


证 从 提 党 所 据 ， 百 则 不 建议 经 党 使用 漠 误 榨 制 运算 符 。 建 议 关 成 良好 的 编码 习惯， 吉 多 | 
一 使 用 错误 检 制 运算 待 ， 而 是 使 用 异常 来 控制 错误 的 发 生 。 在 后 边 有 专门 的 章节 讲述 异 常 。 





2.6.8 三 元 运算 符 


三 元 运算 符 顾 名 思 义 在 三 个 操作 数 之 间 起 作用 。 用 “? : ”表示 。 下 面 用 例子 来 说 明 一 下 它 
的 用 法 。 


【示例 2-9】 三 元 运算 符 。 





后 面 会 讲 到 条 件 控制 语句 下 else， 三 元 运算 符 其 实 就 是 一 个 简化 了 的 让 else 语句 ， 而 null 
合并 运算 符 又 把 三 元 运算 符 简化 了 。 
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2.6.9 NULL 合并 运算 符 


由 于 日 常 使 用 中 存在 大 量 同时 使 用 三 元 表达 式 和 isset() 的 情况 ，NULL 合并 运算 符 使 得 变量 
存在 且 值 不 为 NULL， 它 就 会 返回 自身 的 值 ， 否 则 返回 它 的 第 二 个 操作 数 ， 例 如 : 


2.6.10 ”太空 船 操 作 符 〈 组 合 比较 符 ) 


太空 船 操作 符 用 于 比较 两 个 表达 式 。 当 $a 小 于 、 等 于 或 大 于 $b 时 它 分 别 返回 -1、0 或 1。 
比较 的 原则 是 沿用 PHP 的 常规 比较 规则 进行 的 。 








2.6.11 运算 符 的 优先 级 和 结合 规则 


运算 符 的 优先 级 和 结合 规则 与 正常 的 数学 运算 符 规 则 一 致 : 


@ ”加 减 来 除 的 先后 顺序 与 数学 运算 规则 完全 一 致 ， 先 来 除 后 加 减 。 
@ 有 括号 的 则 先 运算 括号 内 ， 再 运算 括号 外 。 
@ 。 赋值 由 右 向 左 运算 。 


2 .7 流程 控制 


流程 控制 ， 也 叫 控制 结构 ， 在 一 个 程序 中 用 来 控制 如 果 执 行 语句 ， 它 决定 了 某 个 语句 、 表 达 
式 是 否 会 被 执行 和 执行 多 少 次 。 
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PHP 的 控制 语句 分 为 三 类 : 顺序 控制 语句 、 条 件 控制 语句 和 循环 控制 语句 。 其 中 顺序 控制 
语句 就 是 从 上 到 下 依次 执行 ， 没 有 什么 可 以 讲 的 。 下 面 讲 的 是 条 件 控制 语句 和 循环 控制 语句 。 


2.7.1 条 件 控制 语句 if、else、elseif 
这 几 个 条 件 控制 语句 中 让 语句 是 最 常见 的 ， 格 式 如 下 : 


让 只 能 对 一 个 条 件 进行 判断 。 判 断 条 件 成 立 就 执行 命令 ， 反 之 则 不 执行 。 
如 果 希 望 条 件 不 成 立时 执行 另 一 个 命令 ， 就 用 到 了 让..else 语句 ， 它 的 格式 是 : 





虽然 它 也 只 对 一 个 条 件 进行 判断 ， 但 不 管 条 件 是 否 成 立 总 有 一 段 程序 会 相应 运行 ， 故 而 这 个 
语句 运行 的 结果 非 此 即 彼 。 如 果 条 件 成 立 ， 执 行 命令 A;， 如 果 不 成 立 ， 执 行 命令 B。 
如 果 要 判断 的 条 件 会 出 现 多 于 两 种 〈 真 / 假 ) 的 可 能 性 ， 就 是 else 让 语句 上 场 的 时 候 了 ! 





elseif 可 以 出 现 多 次 。 


【示例 2-10】 
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画 ifelseifelse 语句 中 ，elseif 也 可 以 写成 else 认 效果 是 一 样 的 。 


2.7.2 ”条件 控制 语句 switch、case、break、default 


switch 语句 判断 的 结果 可 能 有 多 种 case, 符合 哪个 case， 就 执行 哪个 case 对 应 的 命令 。 如 果 
都 不 符合 ， 就 属于 default 情况 ， 执 行 default 对 应 的 命令 就 可 以 了 。 





【示例 2-11】 条 件 控制 语句 switch。 





2.7.3 “while 循环 语句 


while 语句 也 只 对 一 个 条 件 进行 判断 ， 和 f 语句 不 同 的 是 它 是 循环 执行 的 。 当 “条 件 判断 语 
名 ”为 真 ， 就 执行 后 面 的 命令 ， 然 后 再 返回 “条 件 判断 语句 ”继续 判断 ， 直 到 判断 结果 为 假 时 才 
跳出 循环 。 

它 的 结构 如 下 : 
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【示例 2-12】while 循环 语句 。 





2.7.4 do...while 循环 语句 
do...while 语句 结构 如 下 : 





和 while 语句 不 同 ，do.…while 语句 至 少 会 执行 一 次 do 后 面 的 “命令 执行 语句 ”， 然 后 才 去 
判断 是 否 符合 条 件 。 符 合 就 继续 执行 “命令 执行 语句 ”， 不 符合 则 跳出 循环 。 


例如 : 





2.7.5 _ for 循环 语句 
for 语句 的 功能 很 强大 ， 结 构 也 相对 复杂 : 





大 家 首先 要 和 弄 清楚 exprl、expr2、expr3 代表 什么 。exprl 为 条 件 的 初始 值 ，expr2 为 判断 条 
件 ， 通 常 是 比较 表达 式 或 逻辑 表达 式 。 一 旦 满足 它 的 条 件 ，“ 命 令 执行 语句 ”就 会 得 到 执行 。 然 后 再 
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执行 expr3， 看 结果 是 否 还 符合 expr2 的 判断 一 一 判断 为 真 就 继续 执行 ， 判 断 为 假 就 跳出 循环 。 
例如 : 





2.7.6 _ foreach 循环 语句 
foreach 循环 语句 常用 来 遍历 数组 元 素 ， 它 的 基本 结构 是 


其 实 根据 数组 的 情况 不 同 ， 它 可 以 分 为 以 下 两 种 结构 : 
1. 不 包含 键 值 的 


2. 包含 键 值 的 


每 进行 一 次 循环 ， 当 前 数组 元 素 的 值 就 会 被 赋 给 数组 元 素 变量 ， 而 数组 指针 会 一 一 移动 ， 直 
到 遍历 整个 数组 才 结 束 。 
例如 : 
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2.7.7 ”使 用 break/contine 语句 跳出 循环 


break 在 前 面 介绍 switch 语句 时 已 经 出 现 过 ， 它 可 以 跳出 或 终止 循环 控制 语句 及 条 件 控制 语 
句 中 的 switch 语句 。 

break 后 带 数字 参数 如 break 1、break 2 是 指 break 要 跳出 的 控制 语句 结构 的 层 数 。 

例如 : 





continue 的 作用 是 这 样 的 ， 一 旦 被 执行 ， 它 会 先 从 当前 的 循环 中 跳出 ， 直 接 进入 下 一 个 循环 
和 迭代 ， 继 续 执行 程序 。 
例如 : 





2.8 函数 (function ) 


通俗 地 讲 ， 函 数 是 程序 员 的 工具 ， 有 些 工 具 是 其 他 人 已 经 制作 好 的 ， 像 一 套 螺丝 刀 ， 有 些 则 
需要 你 自己 制作 。 函 数 可 以 实现 一 些 特 定 的 功能 ， 有 些 函 数 需要 输入 参数 ， 有 些 函 数 会 返回 值 。 


2.8.1 函数 的 定义 
一 个 函数 可 由 以 下 的 语法 来 定义 : 


a z 
bh 
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foo 是 函数 名 称 ，$arg 是 传 入 函数 的 参数 ，Sretval 是 函数 返回 的 值 。 

函数 名 和 PHP 中 的 其 他 标识 符 命名 规则 相同 。 有 效 的 函数 名 以 字母 或 下 划 线 打 头 ， 后 面 跟 
字母 、 数 字 或 下 划 线 。 

函数 名 是 大 小 写 无 关 的 ， 不 过 在 调用 函数 的 时 候 ， 使 用 其 在 定义 时 相同 的 形式 是 个 好 习惯 。 


医 任何 有 效 的 PHP 代码 都 有 可 能 出 现在 函数 内 部 ， 甚 至 包括 其 他 函数 和 类 定义 。 
例如 : 


所 有 函数 都 具有 全 局 作用 域 ， 可 以 定义 在 一 个 函数 之 内 而 在 之 外 调用 ， 反 之 亦 然 。 
例如 : 








PHP 不 支持 函数 重 载 ， 也 不 可 能 取消 定义 或 者 重 定义 已 声明 的 函数 。 如 果 需 要 类 似 的 特性 ， 
请 使 用 面向 对 象 来 实现 。 


2.8.2 向 函数 传递 参数 


函数 是 一 个 相对 封闭 的 程序 段 ， 很 多 函数 需要 传递 参数 才能 操作 ， 例 如 : 
echo strlen('1230)1 1/ 输 dh3 


函数 定义 :int strlen ( string $string ) 一 一 获取 字符 串 长 度 。 函 数 strlen 需要 传递 一 个 字符 串 
作为 输入 ， 返 回 值 为 整 型 即 传递 的 字符 串 的 长 度 。 


在 PHP 官网 上 的 文档 中 有 全 部 官方 模块 的 函数 文档 ， 大 约 有 几 千 个 函数 ， 要 完全 掌握 它们 


是 不 现实 的 ， 因 此 在 编写 程序 的 时 候 会 经 常 需 要 搜索 查阅 函数 说 明 ， 迅 速 理解 文档 中 提供 的 
例子 ， 并 掌握 函数 的 使 用 方法 。 
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2.8.3 通过 引用 传递 参数 


默认 情况 下 ， 函 数 参数 通过 值 传递 。 如 果 希 望 允许 函数 修改 它 的 参数 值 ， 必 须 在 函数 定义 中 
该 参数 的 前 面 加 上 符号 &。 


【示例 2-13】 通 过 引用 传递 参数 。 





2.8.4 ”默认 参数 的 值 


函数 的 参数 可 以 设置 默认 的 值 ， 可 以 是 标量 、 数 组 或 null。 默 认 值 必须 是 常量 表达 式 ， 不 能 
是 诸如 变量 、 类 成 员 ， 或 者 函数 调用 等 。 
例如 : 


当 使 用 默认 参数 时 ， 任 何 默 认 参 数 必须 放 在 任何 非 默 认 参 数 的 右 侧 ， 也 就 是 说 ， 有 默认 值 的 
参数 必须 在 最 后 。 





PHP 官方 提供 的 许多 函数 都 使 用 这 一 特性 ， 这 样 做 的 好 处 有 两 点 : 


@ 简化 函数 的 使 用 方式 ， 同 时 也 可 以 简化 代码 。 
@。 如 果 需 要 修改 函数 的 定义 ， 增 加 带 默认 值 的 参数 不 会 影响 现 有 代码 。 
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2.8.5 “参数 类 型 声明 


函数 的 参数 可 以 指定 类 型 ， 当 传 入 类 型 不 对 的 时 候 PHP5 会 报告 致命 错误 ，PHP7 会 抛 出 
TypeError 异常 。 可 以 使 用 的 类 型 参见 表 2.7。 
表 2.7 参数 类 型 


PHP 版 本 





2.8.6 ”可 变数 量 的 参数 列表 


PHP 语言 支持 可 变数 量 的 参数 ， 也 就 是 说 可 以 传 入 任意 多 个 参数 。 使 用 … 对 传 入 参数 进行 
定义 。 在 调用 函数 的 时 候 ， 也 可 以 使 用 … 语 法 传 入 数组 。 
例如 : 





也 可 以 指定 可 变数 量 参数 的 类 型 ， 例 如 : 
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如 果 需 要 修改 可 变数 量 参数 的 值 ， 可 以 以 引用 方式 传 入 参数 ， 例 如 : 





2.8.7 ”使 用 全 局 变量 


在 函数 中 定义 的 变量 只 能 在 函数 中 使 用 ， 外 部 是 无 法 访问 和 使 用 的 。 然 而 函数 中 可 以 使 用 关 
键 字 global 来 使 用 函数 外 部 的 全 局 变量 。 


【示例 2-14】 全 局 变量 。 





2.8.8 使 用 静态 变量 


函数 中 可 以 定义 静态 变量 ， 顾 名 思 义 ， 每 次 调用 函数 时 ， 静 态 变 量 始终 存在 不 会 随 着 函数 执 
行 完成 而 消失 ， 下 次 函数 调用 的 时 候 静 态 变量 的 值 仍 然 可 以 保持 。 


【示例 2-15】 静态 变量 。 
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2.8.9 ”从 函数 返回 值 


使 用 return 语句 从 函数 返回 值 ， 可 以 返回 数组 、 对 象 以 及 其 他 类 型 。 返 回 语句 会 立即 中 止 函 
数 的 运行 ， 并 且 将 控制 权 交 回调 用 该 函数 的 代码 行 ， 例 如 : 


如 果 没有 使 用 return 语句 运 回 任 何 值 ， 则 黑 认 际 认 汉 同 天 null。 





利用 数组 可 以 返回 多 个 值 ， 通 常 搭配 list 函数 使 用 。 
【示例 2-16】 利 用 数组 返回 多 个 值 。 


2.8.10 ”返回 值 类 型 声明 


PHP 7 增加 了 对 返回 类 型 声明 的 支持 。 类 似 于 参数 类 型 声明 ， 返 回 类 型 声明 指明 了 函数 返 
回 值 的 类 型 。 可 用 的 类 型 与 参数 声明 中 可 用 的 类 型 相同 。 


【示例 2-17】 返 回 值 类 型 声明 。 
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2.8.11 可 变 函 数 


在 PHP 中 ， 可 以 将 函数 名 赋值 给 一 个 变量 ， 这 就 是 可 变 函 数 。 在 解析 PHP 代码 的 时 候 ， 如 
果 一 个 变量 名 后 有 圆 括号 ，PHP 将 寻找 与 变量 的 值 同名 的 函数 ， 并 且 尝 试 执行 它 ， 例 如 : 





一 个 典型 的 用 法 是 将 函数 名 称 放 在 一 个 数组 中 ， 然 后 依次 调用 这 些 函 数 ， 例 如 : 





2.8.12 ”匿名 函数 


匿名 函数 (Anonymous functions) ， 也 叫 闭 包 函 数 〈closures) ， 人 允许 临时 创建 一 个 没有 指 
定名 称 的 函数 ， 最 常用 作 回 调 函数 〈callback) 参数 的 值 。 
例如 : 





匿名 函数 也 可 以 有 参数 。 
【示例 2-18】 匿 名 函数 带 参数 。 
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与 用 户 交 互 是 Web 应 用 程序 开发 中 非常 重要 的 一 部 分 。 最 常见 的 用 户 交 互 就 是 用 户 填写 和 
提交 表单 ， 服 务 器 返回 相应 结果 。 这 一 过 程 ， 静 态 的 HTML 页 面 无 法 完成 ， 要 用 PHP 在 服务 器 
端 来 实现 。PHP 脚本 在 服务 器 上 执行 ， 能 够 生成 动态 页 面 内 容 。 


可 . ‖ 表单 处 理 


表单 简单 来 说 就 是 我 们 看 到 的 网 页 ， 本 节 对 表单 的 概念 、 输 入 输出 原理 进行 介绍 。 


3.1.1 表单 简介 


表单 就 是 form， 用 于 集合 不 同类 型 的 用 户 输入 ， 可 以 理解 为 一 个 包含 表单 元 素 的 区 域 。 最 
常见 的 表单 如 图 3.1 所 示 。 


“和 攻 


图 3.1 常见 表单 














【示例 3-1】 forml.php 


图 3.1 这 个 表单 的 HTML 代码: 


仅 有 这 样 的 代码 只 能 让 浏览 器 上 显示 出 form 的 外 形 ， 不 存在 任何 数据 传输 和 提交 的 功能 ， 
是 静态 的 。 所 以 ， 为 了 真正 实现 动态 交互 ， 我 们 需要 在 <form> 里 加 上 以 下 代码 : 


第 3 章 PHP 与 用 户 交互 
或 
<form name="forml" action="forml .php" method="post"> 
在 上 述 代码 里 ，<form> 里 出 现 了 action 和 method 两 个 属性 ， 它 们 的 意义 如 下 : 
@ action: 表单 的 动作 属性 。 定 义 了 当 用 户 单 击 “ 确 认 ” 按 钮 时 ， 表 单 的 内 容 会 被 传送 到 

哪个 目标 文件 ， 也 就 是 要 执行 的 PHP 文件 。 

action 指定 的 URL 不 一 定 在 当前 服务 器 上 ， 也 可 以 指向 任何 一 个 合法 的 URL 地 址 ， 例 如 : 
action='http://my.server.corm/test.php' 








于 如 果 省 略 action 属性 ， 则 表单 内 容 提交 到 当前 URL。 | 











@ ”method: 规定 如 何 发 送 表 单数 据 ， 有 get 和 post 两 个 选项 ， 默 认 是 get。 


3.1.2 GET 和 POST 的 区 别 
如 果 采 用 GET， 浏 览 器 会 和 action 属性 中 指定 的 URL 建立 连接 ， 将 数据 直接 附 在 表单 的 
action URL 之 后 。 这 两 者 之 问 用 问号 进行 分 隔 ， 参 数 之 间 用 & 分 隔 ， 例 如 ; 
http://my.server.com/index.php?cellphone=13912341234&name=test 


如 果 采 用 POST， 浏 览 器 会 和 action 属性 中 指定 的 URL 建立 连接 ， 然 后 将 表单 的 数据 通过 
HTTP 协议 发 送 给 服务 器 端的 PHP 程序 ， 如 图 3.2 所 示 。 


[unr [过 
BS POST test.php 200 OK 


头 信息 Post 响应 HTML 


参数 
cellphone 13912341234 





图 3.2 POST 形式 
GET 和 POST 的 差异 表现 在 : 


@ ”安全 性 上 POST 要 好 得 多 。 使 用 GET 方法 表单 参数 将 会 直接 显示 在 地 址 栏 的 URL 
里 ， 其 他 用 户 可 以 通过 查询 浏览 器 的 历史 记录 轻松 得 到 输入 的 数据 ; 而 POST 就 没有 
这 样 的 安全 漏洞 ，POST 方法 从 表单 发 送 的 信息 对 其 他 人 是 不 可 见 的 ( 所 有 名 称 / 值 会 
被 说 入 HTTP 请 求 的 主体 中 ) 。 

@ ”执行 效率 上 GET 更 好 。 如 果 采 用 POST， 读 取 和 解码 都 更 复杂 一 些 ， 这 是 由 于 它们 的 
传输 方法 不 同 而 造成 的 。 

@ ”POST 传送 的 数据 量 更 大 ， 一 般 默 认为 不 受 限制 。GET 只 能 传送 小 于 2KB 的 数据 。 
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3.1.3 ”PHP 与 表单 处 理 


对 应 于 GET 和 POST，PHP 定义 了 全 局 变量 $ GET、$_POST 和 $_REQUEST。 其 中 $_GET 
将 URL 中 ?以 后 携带 的 参数 解析 成 数组 形式 ， 同 样 地 $_POST 将 HTTP 发 送 过 来 的 POST 参数 
解析 成 数组 形式 ， 而 $_ REQUEST 则 包含 了 GET、POST 和 COOKIE 中 的 所 有 数据 ， 也 是 以 数 
组 形式 存在 。 

下 面 的 章节 会 针对 表单 的 各 种 元 素 讲解 PHP 如 何 处 理 表单 提交 的 参数 。 


也 ,2 表单 元 素 及 处 理 


在 一 个 表单 里 ， 可 以 包含 各 种 不 同 的 元 素 ， 如 文本 字段 、 复 选 杠 、 单 选 按钮 、 提 交 按 钮 等 。 
下 面 我 们 将 分 别 介绍 它们 的 基本 结构 和 处 理 方法 。 


3.2.1 文本 框 


form 中 最 常用 到 的 标签 就 是 input， 文 本 输入 就 是 通过 它 来 实现 的 。 当 然 ， 它 的 用 法 不 止 这 
一 种 ， 我 们 还 会 在 其 他 用 法 中 提 到 它 。 
首先 来 看 一 个 文本 框 的 HTML 代码 : 


它 在 浏览 器 上 生成 的 表单 是 这 样 的 ， 如 图 3.3 所 示 。 














First name: 











Last name: 











图 3.3 名 称 表 单 
而 将 其 中 的 内 容 提 交 到 服务 器 ， 需 要 进行 以 下 修改 。 


【示例 3-2】form2.php 
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如 果 我 们 在 表单 中 输入 一 些 值 ， 单 击 “ 提 交 ” 按 钮 ， 结 果 如 图 3.4 所 示 。 























一 点 题 外 话 ， 在 开发 Web 项 目的 过 程 中 ， 浏 览 器 是 一 个 非常 重要 的 工具 ，Firefox (火狐 ) 提供 
了 开发 者 工具 ， 另 外 还 有 强大 的 Firebug 插件 ，Chrome 谷歌 浏览 器 /微软 最 新 的 Edge 浏览 器 也 有 
内 置 的 开发 者 工具 ， 读 者 应 该 花 点 时 间 学 习 浏览 器 提供 的 工具 ， 可 以 提高 自己 的 工作 效率 。 


a 革 员 党 的 守 码 本 也 是 文本 框 ， 只 是 input 标签 中 type 的 值 设 为 了 “password”。 在 提交 表单 时 
程序 收 到 的 仍 是 用 户 输入 的 数据 ， 与 普通 文本 杠 的 提交 没有 区 别 ， 例 如 : 





文本 域 textarea 可 以 看 作 多 行文 本 框 ， 与 文本 框 功能 相同 ， 例 如 : 
<textarea names='description' ></textarea> 


3.2.2 ” 单 选 按钮 (radio) 与 复 选 框 (checkbox) 
单 选 按钮 和 复 选 框 也 是 通过 input 标签 来 实现 的 ， 只 是 type 的 值 不 同 。 
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1. 单 选 按钮 
单 选 按钮 中 的 type 的 值 设 为 “radio”， 一 个 单 选 按钮 的 HTML 代码 示例 如 下 : 





它 实 现 的 结果 如 图 3.5 所 示 。 





图 3.5 单 选 按钮 
而 将 用 户 提交 的 结果 传送 给 服务 器 ， 需 要 在 HTML 代码 之 后 加 上 以 下 代码 : 


radiobutton 是 单项 选择 ， 所 以 只 能 有 一 个 结果 。 

2. 复 选 框 

复 选 框 中 的 type 的 值 设 为 “checkbox”， 一 个 复 选 框 的 HTML 代码 示例 。 
【示例 3-3】 复 选 框 
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在 微软 的 Edge 浏览 器 显示 如 图 3.6 所 示 。 
您 喜欢 的 交通 方式 〈 可 多 选 ) : 




















图 3.6 复 选 框 


由 于 是 复 选 ， 意 味 着 用 户 可 能 会 选择 多 个 结果 ， 因 此 input 标签 的 name 属性 的 值 是 
checkbox[]， 这 样 用 户 选择 了 多 个 结果 时 PHP 解析 器 会 自动 将 这 个 参数 解析 为 数组 。 如 果 不 加 上 
口 ， 则 会 出 现 参数 值 覆盖 问题 ， 如 图 3.7 所 示 。 


您 喜欢 的 交通 方式 〈 可 多 选 ) : 


array(2) { [0]=> string(5) "plane" [1]=> string(5) "train" } 





图 3.7 参数 值 禾 盖 


可 见 $_GET['checkbox"] 是 一 个 数组 ， 即 使 只 选择 一 个 选项 也 会 解析 成 一 个 数组 ， 并 且 名 称 中 
的 0 被 PHP 解析 器 去 掉 了 。 
那么 问题 来 了 ， 如 果 有 多 个 表单 元 素 重 名 会 出 现 什么 情况 ? 请 读者 自己 试 试 。 


3.2.3 下拉 列表 


下 拉 列 表 与 列表 框 是 通过 select 和 option 标签 来 实现 的 。 
首先 来 看 一 个 下 拉 列 表 的 HTML 代码 : 
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它 在 微软 的 Edge 浏览 器 上 是 这 样 的 ， 如 图 3.8 所 示 。 





图 3.8 下 拉 列 表 


需要 说 明 的 是 select 标签 支持 多 选 ， 这 个 时 候 要 相应 地 将 name 属性 后 面 加 上 0， 告 知 PHP 
解析 器 这 是 个 数组 ， 以 上 代码 修改 后 再 看 看 。 


【示例 3-4】 下 拉 列 表 





在 浏览 器 中 如 图 3.9 所 示 。 
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你 的 选择 是 : array(2) { [0]=> string(6) "不 限 " [1]=> string(16) "五 星 级 /豪华 " } 





图 3.9 多 选 


3.2.4 按钮 


HTML 表单 中 最 常用 的 按钮 是 重 置 按钮 和 提交 按钮 ， 它 们 都 是 通过 input 标签 来 实现 的 ， 只 
是 type 的 值 不 同 而 已 。 
1. 重 置 按钮 


重 置 按钮 可 以 清除 表单 中 的 所 有 数据 ， 使 表单 中 所 有 元 素 恢复 到 初始 状态 。 它 是 通过 将 
input 的 type 值 设 为 reset 来 实现 的 。 
首先 来 看 一 下 重 置 按钮 的 HTML 代码 : 


它 在 浏览 器 上 生成 的 表单 如 图 3.10 所 示 。 








3.10 重 置 按钮 


单 击 “ 重 置 ”按钮 由 浏览 器 直接 处 理 ， 不 会 提交 任何 数据 到 服务 器 ， 所 以 PHP 程序 无 法 直 
接 处 理 重 置 按钮 的 单 击 事件 。 
2. 提交 按钮 


当 用 户 完成 表单 后 ， 需 要 将 数据 发 送 到 服务 器 ， 这 时 需要 提交 按钮 。 它 是 通过 将 input 的 
type 值 设 为 submit 来 实现 的 。 
首先 来 看 一 下 提交 按钮 的 HTML 代码 : 
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它 在 浏览 器 上 生成 的 表单 如 图 3.11 所 示 。 



































图 3.11 提交 按钮 


PHP 解析 器 将 表单 提交 的 数据 分 别 放 到 全 局 变量 $_GET、$_POST、$_REQEST 中 ， 方 便 进 
一 步 处 理 。 


3 e 3 Cookie 


在 跟 用 户 的 交互 中 ， 往 往 需要 识别 用 户 的 身份 并 记录 下 来 。 但 HTTP 协议 的 特点 是 ， 客 户 
端 每 次 与 服务 器 对 话 都 被 当成 一 个 单独 的 过 程 ， 不 保存 状态 。 举 例 而 言 ， 当 用 户 在 第 一 个 页 面 登 
录 后 访问 下 一 个 页 面 仍 要 重新 登录 ， 这 显然 是 不 合适 的 。 

因此 ，Session 和 Cookie 应 运 而 生 ， 它 们 可 以 方便 地 确认 客户 身份 ， 并 临时 保存 一 些 常用 数 
据 。 下 面 我 们 分 别 详细 介绍 一 下 。 

由 于 初学 者 常常 对 Session 和 Cookie 有 些 迷 惑 ， 这 两 个 家 伙 也 确实 有 些 麻烦 ， 下 面 通俗 地 介 
绍 一 下 这 些 概念 ， 希 望 对 读者 理解 Session 和 Cookie 有 所 帮助 。 

HTTP 协议 是 一 个 无 状态 协议 ， 就 像 街 上 摆 挫 卖 包子 ， 钱 货 两 论 。 每 次 浏览 器 和 服务 器 之 间 
的 发 送 和 接收 都 是 钱 货 两 论 ， 服 务 器 不 知道 这 次 的 HTTP 请 求 和 上 次 的 是 一 个 浏览 器 。 

HTTP+Cookie 就 成 了 饭馆 了 ， 每 个 客人 《浏览 器 ) 都 有 个 桌子 ， 服 务 员 〈 服 务 器 ) 给 每 个 
桌子 编 个 号 〈 存 在 Cookie 中 )， 每 次 客人 点 菜 (HTTP 请 求 ) 的 时 候 都 会 告诉 服务 员 〈 服 务 器 ) 
我 的 桌 号 是 ?2? 号 〈Cookie) ， 服 务 员 (服务器 ) 就 会 记录 一 下 1 号 桌 的 客人 点 了 个 龙虾 ， 可 得 记 
到 账 上 ， 不 能 让 他 跑 了 。 

Cookie 就 像 每 个 餐桌 上 放 的 那个 菜单 〈 可 以 修改 ) 。 

Cookie 和 Session 的 相同 之 处 在 于 都 可 以 记录 点 了 什么 菜 ，Cookie 是 给 客人 “浏览 器 ) 看 
的 ， 客 人 可 以 用 一 种 叫 JavaScript 的 餐具 修改 Cookie (是 不 是 很 坏 ? ) ， 服 务 员 〔 服 务 器 〉 在 每 
次 客人 点 菜 (HTTP 请 求 ) 的 时 候 也 会 收 到 Cookie， 为 了 安全 起 见 ， 还 是 别 太 相信 这 个 Cookie 
中 记录 的 菜单 ， 要 是 客人 删除 了 那个 龙虾 就 赔 了 。 

Session 那里 也 可 以 记录 客人 点 了 什么 东西 ， 不 同 之 处 就 在 于 ，Session 是 由 PHP 控制 的 ， 存 
在 服务 器 端 ，Session 通过 在 Cookie 中 设置 一 个 叫做 Session ID 〈 桌 号 ) 的 唯一 性 字符 串 ， 来 标 


66 


第 3 章 PHP 与 用 户 交互 





记 这 个 客人 。 

这 样 当 客人 点 了 龙虾 以 后 ，PHP 控制 的 Session 就 会 记录 下 来 ， 而 客人 的 那个 JavaScript 餐 
有 具 可 修改 不 了 Session， 到 结账 的 时 候 按照 Session 记录 的 付 钱 就 行 了 。 

要 是 这 样 讲 还 是 不 明白 ， 就 去 找 个 饭馆 试 试看 ， 结 账 的 时 候 就 说 “没有 点 那个 龙虾 啊 !”， 
看 看 那个 饭馆 是 相信 你 ， 还 是 相信 他 们 的 计算 机 。 


3.3.1 什么 是 Cookie 


Cookie 是 服务 器 留 在 用 户 计算 机 中 的 小 文件 。 每 当 相同 的 计算 机 通过 同一 个 浏览 器 请 求 页 
面 时 ， 它 同时 会 发 送 Cookie。 
因此 ，Cookie 常用 于 以 下 几 个 方面 : 


@ 识别 用 户 。 

@ 在 页 面 间 传递 变量 。 因 为 浏览 器 并 不 会 保存 当前 页 面 上 的 任何 变量 信息 ， 所 以 一 旦 关 
闭 页 面 ， 它 上 面 的 任何 变量 信息 都 会 消失 。 把 变量 以 Cookie 形式 保存 下 来 ， 其 他 页 面 
就 可 以 通过 读 取 该 Cookie 来 获得 变量 的 值 。 

@ ”记录 访客 的 信息 ， 创 造 更 好 的 用 户 体验 。 


3.3.2 ”如 何 创建 Cookie 
setcookie() 函 数 用 于 设置 Cookie， 它 的 语法 结构 是 : 





PHP 用 一 个 全 局 变量 $_COOKIE 来 存储 这 些 变量 ， 示 例如 下 : 





在 上 面 示例 中 ， 程 序 创建 了 名 为 "user" 的 Cookie， 把 它 赋值 为 "Chloe"。 同 时 也 规定 了 2 小 时 
后 过 期 。 

到 期 后 ，Cookie 文件 将 被 自动 删除 ， 后 面 要 讲 的 删除 Cookie 也 会 提 到 这 一 点 。 如 果 没 有 设 
置 失 效 时 间 ， 关 闭 浏览 器 时 会 自动 删除 Cookie。 
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本 局 setcookie() 函数 必须 位 于 <html> 标签 之 前 ， 和 否则 会 出 错 ! 请 读者 自己 体验 一 下 。 


更 多 的 示例 如 下 : 


上 面 创建 的 Cookie， 除 了 前 面 已 经 提 到 的 内 容 ， 还 设 定 了 域名 ， 在 yourdomain.com 下 有 
效 ， 另 外 ，Cookie 将 使 用 安全 的 HTTPS 协议 传输 〈0 代表 普通 传输 ) 。 


3.3.3 如何 读 取 Cookie 
如 前 所 述 ， 可 以 用 $_COOKIE 变量 取 回 Cookie 的 值 ， 示 例如 下 : 





3.3.4 ”如 何 确认 Cookie 存在 
isset0 函 数 可 以 用 来 确认 是 否 已 设置 了 Cookie。 
【示例 3-5】 确 认 Cookie 存在 。 





3.3.5 ”如 何 删 除 Cookie 
设置 Cookie 的 有 效 时 间 为 过 期 即 可 删除 。 
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3 .4 Session 





3.4.1 什么 是 Session 


由 于 HTTP 是 无 状态 协议 ， 即 使 是 同一 个 用 户 向 服务 器 发 出 不 同 的 请 求 ， 服 务 器 也 无 法 分 
辨 这 是 由 一 个 用 户 发 出 的 。PHP 定义 了 全 局 变量 $_ SESSION， 可 以 在 服务 器 端 存储 用 户 信息 解 
决 这 个 问题 。 

它 的 工作 机 制 是 ， 为 每 个 用 户 创建 一 个 唯一 的 ID， 并 基于 这 个 ID 来 存储 变量 。 默 认 状态 
下 ，Session ID 存储 在 Cookie 里 和 服务 器 端的 文件 或 数据 库 中 ， 服 务 器 通过 读 取 Cookie 中 的 
SessionID， 然 后 在 服务 器 端 找到 对 应 的 Session 文件 来 获取 已 经 保存 在 文件 中 的 Session 值 ， 但 
如 果 客 户 端 浏览 器 无 法 正常 工作 ， 也 可 以 用 URL 方式 传递 它 〈 在 php.ini 中 将 
session.use_trans_sid 设 为 启用 状态 ) ， 不 过 要 注意 安全 隐患 。 

Session 信息 是 临时 的 ， 在 用 户 关闭 浏览 器 后 自动 失效 。 


3.4.2 ”如 何 创建 Session 
启动 Session 可 以 用 session_start() 函 数 。 





上 述 代码 会 向 服务 器 注册 用 户 的 Session， 以 便 开始 保存 用 户 信 息 ， 同 时 会 为 用 户 Session 分 
配 一 个 UID。 





session_start() 函数 必须 位 于 <html> 标签 前 ， 因 为 会 设置 一 个 Cookie， 所 以 必须 在 有 
HTML 输出 之 前 调用 。 
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3.4.3 如何 存储 Session 


在 PHP 中 ， 有 一 个 全 局 变量 $ SESSION。 在 一 个 页 面 对 其 赋值 ， 在 另 一 个 页 面 调 用 就 可 以 
实现 变量 在 页 面 间 的 传递 。 


【示例 3-6】 存 储 Session。 





请 读者 将 这 段 代 码 保存 以 后 在 浏览 器 中 访问 ， 多 刷新 几 次 页 面试 一 下 。 


3.4.4 ”如 何 检测 Session 是 否 存在 
isset() 函 数 可 以 完成 这 一 点 。 上 例 已 经 使 用 过 isset 函数 判断 了 。 
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3.4.5 终结 Session 
unset() 函数 可 以 释放 指定 的 Session 变量 : 


而 session_destroy() 函数 可 以 彻底 终结 Session， 所 有 已 存储 的 Session 数据 都 会 被 重 置 : 








字符 串 〈string) 就 是 字符 序列 ， 如 "Hello world!"， 它 是 PHP 语言 里 一 个 重要 的 数据 类 
型 。 字 符 串 操 作 函 数 是 PHP 的 核心 部 分 ， 必 须 掌 握 。 数 组 是 PHP 中 重要 而 又 复杂 的 数据 类 型 ， 
它 是 一 个 变量 的 组 合 ， 每 一 个 变量 都 叫做 数组 的 一 个 元 素 〈element) 。 对 它 的 索引 叫做 键 名 
(key)， 相 对 应 的 ， 元 素 的 值 叫做 键 值 (value) 。 本 章 就 详细 介绍 字符 串 和 数组 。 


4 .1 字符 申 


4.1.1 字符 串 里 字符 的 类 型 
字符 串 里 的 字符 有 不 同 种 类 ， 列 举 如 下 : 


字母 类 : 如 a、b、c…… 也 包括 中 文字 符 。 
数字 类 : 如 1、2、3*…… 

特殊 字符 类 : 如 #、^、8$…… 

不 可 见 字符 类 : 如 Tab、 回 车 符 、 换 行 符 …… 


@ 
© 
© 
莫 忆 一 个 字符 串 可 以 是 以 上 类 型 的 任意 组 合 ， 并 不 用 局 限 在 某 种 类 型 之 中 。 


4.1.2 ”连接 字符 串 


前 面 我 们 介绍 PHP 语法 时 已 经 提 到 ， 英 文中 的 句号 “.” 可 以 连接 字符 串 。 为 了 帮助 大 家 加 
深 记 忆 ， 这 里 再 用 例子 演示 一 下 。 


【示例 4-1】 连接 字符 串 。 


字符 串 和 数组 





4.1.3 ”计算 字符 串 长 度 strlen() 
这 是 对 字符 串 的 基本 操作 之 一 。strlen0) 函 数 会 返回 字符 串 的 长 度 ， 以 字符 计 。 


荔 GBK 编码 一 个 汉字 占 两 个 字符 ，UTF-8 编码 一 个 中 文 占 三 个 字符 。 


在 中 文 环境 下 ， 判 断 字符 串 长 度 比较 麻烦 ， 因 为 字符 串 有 可 能 是 中 文 ， 英 文 和 数字 的 混合 。 
这 个 时 候 可 以 使 用 mb_strlen() 函 数 ， 例 如 : 














mb_strlen 函数 由 多 字 节 字符 串 mbstring 模块 提供 ， 专 用 来 处 理 PHP 中 的 多 字 节 编码 问题 。 
而 且 mbstring 还 提供 了 在 各 种 字符 编码 之 间 进 行 转换 。 


4.1.4 ”检索 字符 串 


下 面 几 个 看 似 相似 的 函数 都 可 以 对 字符 串 内 指定 的 字符 或 文本 进行 检索 ， 区 别 是 检索 的 方法 
和 标准 不 同 ， 有 具体 说 明 如 下 。 


@ strpos0: 查找 指定 字符 串 在 另 一 字符 囊 中 第 一 次 出 现 的 位 置 ( 区 分 大 小 写 ) 。 

@ strrpos(): 查找 指定 字符 串 在 另 一 字符 串 中 最 后 一 次 出 现 的 位 置 ( 区 分 大 小 写 ) 。 

@ stripos0: 查找 指定 字符 串 在 另 一 字符 串 中 第 一 次 出 现 的 位 置 ( 不 区 分 大 小 写 ) 。 

@ strripos0: 查找 指定 字符 囊 在 另 一 字符 串 中 最 后 一 次 出 现 的 位 置 (不 区 分 大 小 写 ) 。 


返回 的 值 有 两 种 可 能 : 如 果 找 到 匹配 ， 返 回 的 是 位 置 ， 是 整 型 ， 如果 匹配 失败 ， 返 
FALSE， 例 如 : 


回 
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沁 字符 串 中 首 字符 的 位 置 是 0 而 不 是 1， 因 此 要 用 -一 来 判断 是 否 找到 字符 串 ， 因 为 返回 值 有 
可 能 是 0。 


【示例 4-2】 一 的 使 用 。 








喝 嗪 一 铅 ， 尽 量 使 用 -一 、! 一 来 判断 ， 避 免 使 用 一 、! =。 


相对 应 的 ， 所 有 这 些 函 数 都 有 mb 版 本 。 咱 们 需要 处 理 中 文 的 时 候 就 要 使 用 相应 的 mb 版 本 。 

下 面 这 两 个 函数 也 是 用 来 检索 字符 串 。 不 同 的 是 ， 它 们 返回 的 值 是 从 匹配 点 开始 的 字符 串 剩 
余部 分 。 也 就 是 说 ， 上 一 组 函数 是 告诉 你 个 编号 ， 这 一 组 函数 则 是 把 剩 下 的 字符 〈 包 括 搜索 的 那 
个 ) 都 提取 出 来 。 


@ strstr : 返回 搜索 字符 囊 第 一 次 出 现 的 位 置 开始 到 结尾 的 部 分 。 
@ stristr : 同上 ， 但 是 不 区 分 大 小 写 。 这 里 的 “i” 是 insensitive 的 意思 。 


例如 : 


值得 一 提 的 是 PHP 的 官方 文档 很 有 意思 ， 请 看 官方 的 函数 说 明 : 


@ haystack: 干草 堆 。 
@ needle: 针 。 


这 些 检索 类 的 函数 都 是 在 干草 堆 里 找 针 。 相 对 应 的 也 有 mb_strstr 和 mb_stristr 来 检索 多 字 节 
字符 串 。 


符 串 和 数组 





4.1.5 ”截取 字符 串 


substr( 目 标 字符 串 , 起 始 位 置 [， 截 取 长 度 ]) ， 它 的 作用 是 返回 目标 字符 串 的 一 部 分 。 其 中 
截取 长 度 是 可 选 参数 ， 如 果 没有 提供 ， 返 回 的 子 字符 中 将 从 起 始 位 置 开始 直到 字符 串 结尾 。 


“起 始 位 置 ”必须 是 整数 。 如 果 是 正 数 ， 从 字符 串 的 指定 位 置 开始 截取 即 可 ; 如 果 是 0 应 | 
从 字符 串 的 第 一 个 字符 处 开始 ; 如 果 是 负数 ， 从 字符 囊 结尾 开始 的 指定 位 置 开始 。 
《截取 长 度 ” 也 必须 是 整数 。 如 果 是 正 数 ， 从 “起 始 位 置 ”参数 所 在 的 位 置 算 长 度 ; 如 果 是 
负数 ， 则 从 字符 串 未 端 算 起 ， 返 回 的 是 从 “起 始 位 置 ”开始 直到 扣除 从 字符 串 未 端 算 起 “ 共 
\ 取 长 度 ”字符 串 以 外 的 全 部 字符 。 





相对 应 的 也 有 mb_substr 函数 。 
substr 的 使 用 方法 比较 灵活 ， 建 议 使 用 的 时 候 尽 量 使 用 正 整 数 ， 使 用 负数 的 时 候 务 必 小 心 。 


4.1.6 ”替换 字符 串 
PHP 主要 有 三 个 函数 用 来 查找 和 替换 字符 串 ， 我 们 依次 来 介绍 。 


(1) str_replace()、str_ireplace() 两 个 函数 都 可 以 用 来 替换 字符 串 中 的 一 些 字符 ， 区 别 还 是 
str_replace() 对 大 小 写 敏感 ，str_ireplace() 则 不 是 。 


str_replace0) 的 语法 是 : 


参数 count 是 可 选 的 ， 是 对 替换 数 进行 计数 的 变量 。 这 是 在 PHP 5.0 中 新 增 的 参数 。 
如 果 被 搜索 的 字符 串 是 数组 ， 那 么 函数 的 返回 结果 仍 是 数组 。 
如 果 被 搜索 的 字符 串 是 数组 ， 函 数 执行 时 会 对 数组 中 的 每 个 元 素 进行 查找 和 替换 。 





ss 
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(2) substr replace0) 的 作用 是 把 字符 串 的 一 部 分 蔡 换 为 另 一 个 字符 串 。 


从 参数 就 可 以 看 出 ， 它 和 上 面 str_replace()、str_ireplace0 函 数 的 不 同 是 ， 不 依靠 检索 到 匹配 
字符 串 再 进行 奉 换 ， 而 是 根据 指定 位 置 及 长 度 进行 蔡 换 。 





“起 始 位 置 ”的 值 : 正 数 无 须 多 说 ，0 则 默认 从 第 一 个 字符 处 开始 ， 这 和 前 面 讲 过 的 字符 串 
检索 相 吻 合 ， 负 数 仍 意味 着 从 字符 串 结尾 的 指定 位 置 开始 替换 。 

“替换 长 度 ” 的 值 : 正 数 、 负 数 和 0。 正 数 不 讲 了 ，0 相当 于 插入 操作 ， 负 数 则 表示 待 替换 
的 子 字符 串 结尾 处 距离 目标 字符 串 末端 的 字符 个 数 。 





例如 : 





4.1.7 ”清理 字符 串 


字符 串 中 有 时 会 有 多 余 的 空格 ， 而 这 些 空格 有 时 又 会 影响 程序 的 正常 执行 。 所 以 清理 空格 是 
很 实用 的 操作 。 这 里 介绍 一 组 PHP 里 的 清理 函数 : ltrim0、rtrim0、trim0。 它 们 的 语法 相同 ， 区 
别 只 是 清理 的 顺序 而 已 。 

具体 如 下 。 


@ ltrim(0): 移 除 字符 串 左 侧 的 空白 字符 或 其 他 预定 义 字符 。 
@ rtrim0: 移 除 字符 囊 右 侧 的 空白 字符 或 其 他 预定 义 字符 。 
@ ”trim(): 移 除 字符 串 两 侧 的 空白 字符 或 其 他 预定 义 字 符 。 


下 面 以 ltrim0) 为 例 介绍 一 下 语法 结构 : 
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这 里 的 “ 需 删 除 字符 ”并 不 是 必须 的 。 如 果 省 略 该 参数 ， 则 移 除 下 列 所 有 字符 : 
0": NULL. 

At": 制 表 符 。 

"m": 换行 。 

"x0B": 垂直 制 表 符 。 

MW 车 。 

"": 空格 。 








例如 : 


4.1.8” 切 分 和 组 合 字 符 串 


explode() 函数 可 以 把 字符 串 打 散 为 数组 ，implodeQ 函数 则 刚好 相反 。 
它们 的 语法 结构 如 下 : 





下 面 用 例子 来 说 明 这 两 个 函数 是 如 何 使 用 的 。 





看 看 输出 效果 : 


注意 ，implode 可 以 直接 将 数组 组 合 ， 例 如 : 
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echo implode( ['a', 'b','c','d'] ) ; // 输 出 : abcd 


4.1.9 其 他 常用 字符 串 函 数 
篇 幅 所 限 ， 这 里 将 其 他 常用 字符 串 函 数 简单 列 一 下 ， 请 读者 自学 。 


1. 转 义 与 反 转 义 字符 串 

addslashes: 使 用 反 斜 线 转 义 字符 串 。 

addcslashes: 以 C 语言 风格 使 用 反 针 线 转 义 字符 串 中 的 字符 。 
stripcslashes: 反 转 义 一 个 使 用 addcslashes 转 义 的 字符 串 。 
stripslashes: 反 转 义 一 个 用 addslashes 转 义 的 字符 串 。 
quotemeta: 将 .\+*#?[^]($) 前 加 反 斜 线 (\) 转 义 。 


2. 字符 串 进 制 转换 
@ bin2hex: 把 ASCII 字 符 的 字符 串 转 换 为 十 六 进 制 值 字符 事 。 
@ ”hex2bin: 转换 十 六 进 制 字符 串 为 ASCII 字符 的 字符 串 。 

. 字符 串 分 割 


3 
@ chunk split: 将 字符 串 分 害 成 小 块 ， 并 加 上 换行 符 \n。 

@。 wordwrap: 打 断 字符 串 为 指定 数量 的 字 串 ， 并 加 上 换行 符 m。 
@@ 

@@ 


str_split: 将 字符 串 转 换 为 数组 。 
split: 用 正则 表达 式 将 字符 串 分 割 到 数组 中 ， 这 个 与 explode 有 些 像 ， 但 是 支持 正则 表 
4. 字符 串 加 密 
@ md5; 计算 字符 串 的 MD5 哈 希 值 。 
@ crc320: 计算 一 个 字符 串 的 crc32 多 项 式 。 
@ shal0: 计算 字符 囊 的 shal 散 列 值 。 
@ hash0: 生成 哈 希 值 。 


处 理 CSV 字符 串 
str_getcsv: 解析 CSV 字符 串 为 一 个 数组 。 


处 理 字符 串 的 函数 有 近 百 个 (98 个 ) ， 读 者 应 像 学 习 英 语 一 样 进行 精读 和 通读 ， 掌 握 常用 
函数 名 称 及 功能 ， 一 般 了 解 其 他 函数 的 使 用 方法 。 
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人 入. 2 数组 的 类 型 


数组 的 分 类 有 两 种 ， 按 照 索引 方法 ， 可 以 分 为 数字 索引 数组 和 关联 索引 数组 ， 按 照 维度 ， 可 
以 分 为 一 维 数组 和 多 维 数组 。 


4.2.1 数字 索引 数组 


对 于 数字 索引 数组 ， 可 以 想象 成 工 号 和 人 一 一 对 应 的 关系 。 工 号 相当 于 键 名 ， 人 相当 于 键 
值 。 唯 一 不 同 的 是 ， 数 字 索 引 数组 键 名 是 从 0 开始 的 ， 它 是 最 基础 的 数组 类 型 。 

创建 数组 既 可 以 整体 赋值 ， 也 可 以 一 个 元 素 一 个 元 素 单独 赋值 。 在 PHP 中 ，array() 函数 用 
于 创建 数组 ， 示 例如 下 : 


在 这 种 整体 赋值 中 ， 键 名 是 自动 分 配 的 〈 从 0 开始 ) 。 


也 可 以 直接 给 元 素 赋值 ， 手 动 分 配 键 名 。 


也 可 以 用 省 略 键 名 的 方法 增加 新 的 元 素 ， 系 统 会 自动 将 其 键 名 设 为 已 有 最 大 键 名 加 1。 下 面 
例子 中 的 "瓜子 "会 被 自动 设 定 为 键 名 为 “3”。 





4.2.2 关联 索引 数组 


关联 索引 数组 的 键 名 不 再 局 限 为 数字 ， 可 以 是 字符 串 和 数字 的 混合 ， 可 以 把 这 时 的 键 名 和 键 
值 的 关系 想象 为 名 字 和 人 的 一 一 对 应 。 
同样 的 ， 它 也 支持 整体 赋值 和 逐个 赋值 ， 示 例如 下 : 


。 $pricer=array(" 饼 干 "->6, "巧克力 "=->12, "蛋糕 "->8) 
或 : 
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4.2.3 多维 数 组 


以 上 举 的 例子 都 是 一 维 数组 ， 多 维 数组 指 的 是 包含 一 个 或 多 个 数组 的 数组 ， 像 数组 的 “ 顽 
套 ” 


如 表 4.1 所 示 显示 食物 的 进 价 和 售 价 : 
表 4.1 食物 的 进 价 和 售 价 





如 果 需 要 用 数组 来 存储 这 些 数据 ， 就 要 用 上 二 维 数组 了 。 





相应 的 ， 如 果 要 访问 里 面 的 元 素 ， 必 须 使 用 两 个 索引 ， 相 当 于 “ 行 ” 和 “ 列 ”。 
【示例 4-3】 访 问 二 维 数组 。 





输出 以 下 结果 : 
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外 .了 统计 数组 元 素 个 数 count() 函 数 


实际 应 用 中 ， 有 时 需要 统计 数组 元 素 的 个 数 ，count0 函 数 的 功能 就 在 于 此 。 它 的 语法 结构 


上 面 参 数 中 ，“ 数 组 ”是 必须 的 ; “统计 模式 ”可 选 。 如 果 设 为 “0”， 这 也 是 它 的 默认 
值 ， 将 只 统计 数组 最 上 面 一 层 的 元 素 ， 在 多 维 数组 时 起 作用 ; 如 果 设 为 “1”， 则 递归 地 统计 数 
组 中 所 有 元 素 ， 例 如 : 





对 于 多 维 数组 ， 参 考 下 面 的 例子 。 
【示例 4-4】 多 维 数组 。 





以 上 代码 输出 : 
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4.4 用 foreach 遍历 数组 


遍历 数组 就 是 把 数组 中 的 每 个 元 素 都 读 出 来 ， 经 常用 到 的 是 foreach 语法 结构 ， 例 如 : 





4.5 设置 数组 指针 一 一 reset()、end()、 
next()、prev()、current()、each() 


每 个 数组 中 都 有 一 个 内 部 的 指针 指向 它 “ 当 前 的 ”元 素 ， 初 始 指针 指向 插入 到 数组 中 的 第 一 
个 元 素 。 当 使 用 foreach 遍历 数组 后 ， 数 组 指针 指向 数组 的 最 后 一 个 元 素 。 如 果 想 将 数组 的 指针 
重 置 回 第 一 个 元 素 ， 可 以 使 用 reset0 函 数 。 

相对 应 的 ， 还 有 以 下 几 个 函数 可 以 操作 数组 指针 。 





@ current(): 返回 数组 中 的 当前 元 素 的 值 。 

end0: 将 内 部 指针 指向 数组 中 的 最 后 一 个 元 素 ， 并 输出 。 
nextO: 将 内 部 指针 指向 数组 中 的 下 一 个 元 素 ， 并 输出 。 
prev(): 将 内 部 指针 指向 数组 中 的 上 一 个 元 素 ， 并 输出 。 
each0: 返回 当前 元 素 的 键 名 和 键 值 ， 并 将 内 部 指针 向 前 移动 。 
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入 .OO 数组 排序 


在 PHP 中 ， 支 持 对 数组 的 多 种 排序 ， 这 里 我 们 将 介绍 几 组 排序 函数 。 


4.6.1 默认 排序 sort()、 rsort() 
sort0 函 数 对 数字 索引 数组 进行 升序 排序 ，rsortO 刚 好 相反 《降序 ) 。 
【示例 4-5】 对 数字 索引 数组 进行 升序 排序 。 
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如 果 内 容 是 字符 串 ， 则 按照 字母 顺序 排序 ， 例 如 : 





3 这 两 个 函数 都 将 为 数组 中 的 元 素 赋予 新 的 键 名 。 这 将 删除 原 有 的 键 名 ， 而 不 是 仅仅 将 键 名 重 
新 排序 。 


另外 ，sort()、rsort() 都 支持 设置 按 哪 种 类 型 排序 ， 以 sort() 为 例 ， 它 的 语法 结构 为 : 





其 中 “排序 类 型 ”是 可 选 参 数 ， 常 用 的 值 如 下 : 


0 = SORT REGULAR: 默认 。 把 每 一 项 按 常 规 顺序 排列 (标准 ASCII 码 ， 不 改变 类 
型 ) 。 

1=SORT NUMERIC: 把 每 一 项 作为 数字 来 处 理 。 

2=SORT _ STRING: 把 每 一 项 作为 字符 串 来 处 理 。 

3 = SORT LOCALE STRING: 把 每 一 项 作为 字符 串 来 处 理 ， 基 于 当前 区 域 设置 (可 通 
过 setlocale() 进行 更 改 ) 。 

4=SORT_NATURAL: 把 每 一 项 作为 字符 串 来 处 理 ， 使 用 类 似 natsort() 的 自然 排序 。 
5 = SORT_FLAG CASE: 可 以 结合 ( 按 位 或 ) SORT_STRING 或 SORT NATURAL 
对 字符 串 进行 排序 ， 不 区 分 大 小 写 。 


【示例 4-6】 对 字符 串 进行 排序 。 
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4.6.2 ”关联 索引 数组 按照 键 值 排序 asort()、arsort() 


对 于 关联 索引 数组 ， 保 持 索引 关系 排序 非常 重要 。asort0 可 以 对 关联 索引 数组 按照 键 值 进行 
升序 排序 ，arsort0 刚 好 相反 《降序 ) 。 
示例 如 下 : 





4.6.3 ”关联 索引 数组 按照 键 名 排序 ksort()、krsort() 
对 于 关联 索引 数组 ，ksortO 可 以 按照 键 名 进行 升序 排序 ，krsor 刚 好 相反 《〈 降 序 ) 。 示 例如 下 : 
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人 处. 7 数组 常见 操作 


4.7.1 向 数组 添加 新 元 素 array_push()、array_unshift() 


数组 操作 中 ， 经 常 要 用 到 添加 和 删除 元 素 。array_push0)、 array_unshift() 都 可 以 向 数组 添加 
新 元 素 ， 只 是 插入 的 位 置 不 同 。 


@ array_push() 函 数 向 数组 尾部 添加 元 素 ， 可 以 想象 为 排队 时 不 断 有 人 按 顺 序 加 入 队伍 。 
@ array_ unshift() 函数 向 数组 的 开头 添加 元 素 ， 可 以 想象 为 往 弹 夹 里 压 子 弹 。 


例如 : 


如 果 用 array_push0 来 给 数组 增加 一 个 元 素 ， 用 $array[] = 更 好 一 些 ， 因 为 这 样 没有 调用 函数 
的 额外 负担 。 





4.7.2 ”删除 数组 元 素 array_pop()、array_shift() 


array_pop0 函 数 删除 数组 中 的 最 后 一 个 元 素 ， 返 回 数 组 的 最 后 一 个 值 。array_shift() 删 除数 组 
中 第 一 个 元 素 ， 并 返回 被 删除 元 素 的 值 。 
示例 如 下 : 
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4.7.3 ”删除 数组 中 的 重复 值 array_unique() 

有 时 数组 中 的 元 素 会 被 重复 输入 ， 用 array_unique0 可 以 解决 这 种 情况 。 

array_unique() 函数 可 以 删除 数组 中 重复 的 值 。 如 果 数 组 中 多 个 元 素 的 值 相同 ， 将 只 保留 第 
一 个 元 素 ， 删 除 其 他 的 。 返 回 值 为 结果 数组 。 

例如 : 





即使 键 名 不 同 ， 仍 然 会 去 掉 重 复 的 元 素 ， 只 保留 第 一 个 ， 例 如 : 
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4.7.4 ”对 数组 进行 查询 in_array() 


因为 数组 是 元 素 的 集合 ， 经 常 需要 对 数组 查询 ， 所 以 常常 用 到 in_array0) 函 数 。in_array() 函 
数 查询 数组 中 是 否 存在 指定 的 值 。 


【示例 4-7 】 对 数组 进行 查询 。 





4.7.5 其 他 常用 数组 函数 array_keys()、array_values()、unset() 
@ array_keys() 函 数 : 返回 包含 数组 中 所 有 键 名 的 一 个 新 数组 。 
示例 如 下 : 





@ array values0 函 数 : 返回 包含 数组 中 所 有 键 值 的 新 数组 ， 例 如 : 





| 





@ unset() 函数 : 删除 数组 中 的 元 素 ， 例 如 : 








在 实际 做 项 目 时 ， 日 期 和 时 间 常 常 是 编程 首先 要 考虑 的 部 分 。 日 期 和 时 间 不 正确 ， 程 序 往往 
无 法 正常 运行 。 无 论 是 订 票 、 订 房间 还 是 安排 日 程 ， 离 开 日 期 和 时 间 编 程 都 是 没有 意义 的 ， 所 以 
了 解 相关 的 常用 函数 非常 有 用 。 

在 本 章 将 会 学 到 : 


设置 时 区 。 

获取 UNIX 时 间 蕉 : time(。 

根据 时 间 戳 获取 日 期 和 时 间 : date()。 

根据 日 期 和 时 间 获 取 时 间 玲 : mktime()、strtotime()。 
根据 时 间 鹤 获取 包含 日 期 信息 的 数组 : getdate()。 
验证 日 期 的 有 效 性 : checkdate()。 

输出 指定 格式 的 日 期 和 时 间 : strftime()。 


与 . 1 设置 时 区 


首先 介绍 一 下 时 区 的 概念 ， 它 的 英文 翻译 是 time zone， 是 地 球 上 的 区 域 使 用 同一 个 时 间 定 
义 。 全 球 划分 为 24 个 时 区 ， 中 国 采用 首都 北京 所 在 的 东 八 区 ， 即 UTC/GMT+08:00。 

PHP 中 日 期 和 时 间 的 默认 设置 是 格林 尼 治 时 间 (GMT) ， 与 我 们 当前 的 时 区 不 符 ， 故 而 需 
要 重新 设置 。 

设置 时 区 可 以 用 以 下 两 种 方式 : 


@ 在 phpini 中 设置 ， 找 到 "datetimezone = "和 选项， 将 其 设置 为 
date.timezone=Asia/Shanghai。 

@ 在 代码 中 设置 ， 调 用 函数 date default timezone set() ， 并 将 其 中 的 参数 设 为 
Asia/Shanghai, date_default timezone set("Asia/Shanghai"). 


为 了 保证 程序 的 正确 运行 ， 一 定 要 在 一 开始 就 设置 好 正确 的 时 区 。 


获取 UNIX 时 间 戳 


再 介绍 一 下 UNIX 时 间 戳 (imestamp) 的 概念 : 一 种 时 间 表 示 方 式 ， 定 义 为 从 格林 尼 治 时 间 
1970 年 01 月 01 日 00 时 00 分 00 秒 起 至 现在 的 总 秒 数 。 

与 其 他 时 间 表 示 方 式 相 比 ， 它 不 要 求 格式 〈 如 月 日 年 等 ) 、 不 需要 换算 ， 非 常 容 易 处 理 。 
PHP 系统 完全 采用 了 这 个 概念 。 

获取 当前 时 间 戳 的 函数 叫 time()， 它 的 用 法 如 下 : 


echo time () 7 // 输 出 : 1454265134 
echo time ()+ 7* 24 * 3600 ; // 一 周 之 后 的 时 间 戳 


,了 根据 时 间 故 获取 日 期 和 时 间 


date(0) 函 数 把 时 间 戳 格式 化 为 更 易 读 的 日 期 和 时 间 。 它 的 语法 格式 如 下 ; 


date (时 间 格 式 [, 时 间 戳 ]) 
date (format [,timestamp] ) 


其 中 “时 间 戳 ”是 可 选 参数 ， 如 果 不 设 默认 值 ， 则 是 系统 当前 时 间 戳 。 
“时 间 戳 格式 ”必须 设 定 ， 常 用 的 参数 见 表 5.1。 
表 5.1 时 间 戳 格式 


参数 。” 含义 














mm 12 pr -IJ 
| 大 写 AM 或 PM | 日 | 4 小 时 格式 的 小 时 数 (00-23) 
rE Tr 分 名 数 (01-60) 
月 份 (01~12) 秒 数 (00~59) 
月 份 的 英文 全 拼 显示 时 区 
月 份 简写 (Jan~Dec) 时 区 简写 
t 每 月 天 数 总 和 (28~31) 星期 儿 简写 (Mon~Sun) 
VY 年 (四 位 数 ) U 当前 UNIX 时 间 戳 
例如 : 


echo date('Y-m-d H:i:s'); // 输 出 : 2016-01-31 20:01:25 
echo date ('Y-m-d'，0) ; // 输 出 : 1970-01-01 
echo date('Y-m-d'，time()+ 3*24*3600); //3 天 以 后 的 同一 时 间 : 2016-02-03 
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鳃 他 字符 ,比如 "、"" 或 也 可 被 插入 格式 字符 中 ， 以 美化 时 间 客 式 。 如 : 
date("Y/m/d") 或 date("Y-m-d") 等 。 











与 .人 根据 日 期 和 时 间 获取 时 间 截 


mktime() 函数 返回 一 个 日 期 的 Unix 时 间 铃 。 它 的 语法 格式 如 下 : 





这 些 参数 可 以 空缺 ， 默 认为 当前 的 日 期 时 间 。 





strtotime() 函 数 将 任何 英文 文本 的 日 期 时 间 描 述 转换 为 Unix 时 间 锥 。 它 的 语法 格式 如 下 : 





如 果 不 设置 “now"， 默 认 使 用 当前 时 间作 为 计算 返回 值 的 时 间 戳 。 一 般 来 说 ，strtotime 的 用 
途 在 于 将 文本 表示 的 时 间 转 为 整形 表示 的 时 间 ， 便 于 进一步 计算 ， 例 如 : 











strtotime 函数 相当 灵活 ， 请 使 用 的 时 候 做 好 测试 工作 。 | 








与 . 与 ”根据 时 间 惟 获取 包含 日 期 信息 的 数组 


getdate() 函 数 可 以 返回 一 个 根据 指定 时 间 戳 得 出 的 包含 日 期 信息 的 数组 。 如 果 没 有 给 出 时 间 
戳 ， 则 默认 是 当前 本 地 时 间 。 它 的 语法 格式 如 下 : 


92 





第 5 章 日 期 与 时 间 





日 期 信息 的 数组 说 明 如 表 5.2 所 示 。 
表 5.2 日 期 信息 的 数组 说 明 








键 名 含义 返回 值 说 明 
“ead | ns 
"minutes" 059 
"hours" 023 
“mda al 
"wday" 0 (表示 星期 天 ) ~6 (表示 星期 六 ) 
mo | | 
"year" 如 2016 
"yday" 0-365 
"weekday" Sunday~ Saturday 
"month" January-December 
从 UNIX 纪元 开始 至 今 的 秒 数 ， 和 time0 的 

0 返回 值 以 及 用 于 date0 的 值 类 似 -2147483648~2147483647 

【示例 5-1】 


与 .OO ”验证 日 期 的 有 效 性 


checkdate() 函 数 可 以 验证 输入 日 期 是 否 合法 有 效 。 具 体 标准 为 : 


@ 年 份 值 应 在 1~32767。 
@ 月 份 值 应 在 1~12。 
@ 日 期 应 在 给 定 月 份 应 有 的 天 数 之 间 ， 关 年 已 经 考虑 进去 了 。 


它 的 具体 语法 结构 是 : 


例如 : 
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与 . /输出 指定 格式 的 日 期 和 时 间 


strfime() 函 数 可 以 根据 区 域 设置 格式 化 本 地 时 间 / 日 期 。 它 与 date 函数 的 主要 不 同 是 
strftime 支持 国际 化 ， 因 此 要 显示 其 他 语言 的 时 间 / 日 期 格式 的 时 候 需 要 用 strfime 函数 。 它 的 语 
法 结构 如 下 : 


strftime (format [,timestamp]) 
strftime (格式 【, 时 间 戳 ] ) 


时 间 戳 参数 是 可 选 的 ， 其 默认 值 是 系统 当前 时 间 。 
“格式 ”参数 的 说 明 见 表 5.3。 
表 5.3 “格式 ”参数 的 说 明 




















代码 说 明 代码 说 明 
%a 星期 几 的 简写 (Sun~SaD) AM 或 PM 
%A 星期 几 的 全 拼 (Sunday~Saturday) 12 小 时 的 时 间 ， 如 07:12:36 
%b 或 %h | 月 份 的 简写 Jan~Dec) 24 小 时 的 时 间 ， 如 17:25 
%B 月 份 的 全 拼 (January~December) 秒 (00-59) 
%C 世纪 ， 如 21 Tab 字符 ， 同 "At 
%d 月 份 中 的 第 几 天 〈01-31) hh:mm:ss 
%D 日 期 ，mmvdd/y 每 周 的 第 几 天 〈1~7，1 为 Monday) 
%e 月 份 中 的 第 几 天 01-31) 本 年 的 第 几 周 ， 从 第 1 周 的 第 1 个 星期 天 开始 
wg 2 位 数 的 年 份 ， 如 16 (2016) 本 年 的 第 几 周 ， 从 第 1 个 至 少 还 有 4 天 的 星期 开始 
%G 4 位 数 的 年 份 ， 如 2016 星期 中 的 第 几 天 (0-6，0 为 Sunday) 
%H 24 小 时 制 的 小 时 (00-23) %W 一 年 中 的 第 几 周 ， 从 第 1 周 的 第 1 个 星期 一 作为 开始 
%I 12 小 时 制 的 小 时 (1~12) x 标准 格式 日 期 ， 无 时 间 
%j 年 份 中 的 第 几 天 %X 标准 格式 时 间 ， 无 日 期 
(001~366) 

%m 月 份 (01~12) 两 位 数 显示 年 份 ， 如 16 
%M 分 钟 (00~59) %Y 四 位 数 显示 年 份 ， 如 2016 
%n 换行 符 ， 同 "\n" %z 或 %Z | 时 区 
%p am 或 pm 

例如 : 

echo strftime( '%x'); // 输 出 : 02/01/16 











一 有 此 国家 日 期 格式 是 月 /日 /年 ， 而 有 些 则 是 日/ 月 /年 。 | 
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面向 对 象 的 日 期 时 间 类 


自从 PHP 5.2 开始 ，PHP 提供 了 一 套 面 向 对 象 的 日 期 时 间 类 ， 大 大 简化 了 时 间 日 期 的 使 用 难 
度 。 虽 然 我 们 还 没有 详细 介绍 类 与 对 象 的 相关 知识 ， 但 使 用 一 个 编写 好 的 类 没有 任何 问题 ， 仅 仅 
需要 了 解 一 点 调用 类 方法 的 语法 知识 即 可 。 

许多 日 期 时 间 类 的 方法 也 有 实现 同样 功能 的 过 程 化 风格 的 函数 ， 本 章 介 绍 常用 的 一 些 类 。 


5.8.1 DateTime 类 


先 列 一 下 DateTime 类 中 定义 的 一 些 预定 义 常量 ， 见 表 5.4。 


表 5.4 预定 义 常量 
常量 名 称 常量 值 
ATOM Y-m-d\TH:i:sP 
COOKIE 
ISO8601 
RFC822 
RFC850 
RFC1036 
RFC1123 D,dMYH:isO 
RFC2822 D,dMYH:isO 
RFC3339 
RSS 
W3C Y-m-d\TH:i:sP 











这 些 常 量 定义 了 一 些 国际 标准 中 使 用 的 时 间 格式 ， 其 中 的 值 使 用 的 和 date 函数 格式 是 一 样 
的 。 我 们 可 以 在 date 函数 中 使 用 这 些 常量 ， 例 如 : 


echo date (DateTime::ATOM); // 输 出 : 2016-02-03T11:17:16+01:00 
下 面 是 DateTime 类 的 一 些 常 用 方法 。 


@ 。 _construct: 构造 函数 ， 返 回 一 个 新 的 日 期 时 间 对 象 。 

@ ”Add: 增加 一 段 时 间 ， 参 数 为 DateInterval 对 象 。 

@ createFromFormat: 静态 方法 ， 根据 指 定 的 格式 和 时 间 字 符 串 (可 选 ) 返回 一 个 新 的 日 
期 时 间 对 象 。 

di 人 返回 两 个 日 期 时 间 对 象 的 时 间 差异 。 

format: 返回 指定 日 期 时 间 格式 的 字符 串 。 

getLastErrors: 返回 错误 和 警告 信息 。 

getOffset: 返回 时 区 偏 移 量 ， 用 正 负 秒 数 表示 。 


95 


PHP+MySQL 网 站 开发 从 零 开始 学 〈 视 频 教学 版 ) 





getTimestamp: 返回 时 间 蕉 .。 

getTimezone: 返回 时 区 。 

modify: 修改 时 间 戳 ， 支 持 strtotime 函数 支持 的 字符 串 格式 。 
setDate: 设置 年 月 日 。 

setTime: 设置 时 分 秒 ， 其 中 秒 为 可 选 参数 。 

setTimestamp: 设置 时 间 鹤 。 

setTimezone: 设置 时 区 。 

sub: 减 去 一 段 时 间 ， 参 数 为 DateInterval 对 象 。 


下 面 列举 一 些 常用 函数 的 例子 。 
【示例 5-2】 时 间 常 用 函数 。 





5.8.2 DateTimelmmutable 类 


DateTimeImmutable 类 与 DateTime 非常 类 似 ， 没 有 那些 预定 义 常量 (因为 没有 必要 定义 两 
次 ) ， 主 要 的 区 别 是 DateTimeImmutable 的 大 多 数 方 法 会 返回 一 个 新 的 DateTimeImmutable 对 
象 ， 而 本 身 则 不 会 改变 。 


96 


攻 ”第 5 章 日 期 与 时 间 





5.8.3” ”DateTimeZone 类 


DateTimeZone 类 用 来 进行 时 区 相关 的 运算 ， 主 要 用 于 DateTime 的 setTimeZone/ 
getTimeZone 方法 。 


DateTimeZone 类 的 常用 方法 如 下 : 


@ _construct: 构造 函数 ， 传 入 一 个 字符 串 来 创建 一 个 DateTimeZone 对 象 ， 例 如 
Asia/Shanghai。 

getLocation: 返回 时 区 的 位 置信 息 。 

getName: 返回 时 区 的 名 称 。 

getOffset: 返回 时 区 相对 于 GMT 的 偏 移 量 。 

getTransitions: 返回 时 区 转换 。 

listAbbreviations: 返回 一 个 包含 DST (夏令 时 ) 、 时 差 和 时 区 信息 的 关联 数组 。 
listIdentifiers: 返回 一 个 包含 了 所 有 时 区 标示 符 的 索引 数组 。 


【示例 5-3】 时 区 操作 。 
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5.8.4 ”Datelnterval 类 


DateInterval 类 用 来 表示 一 段 时 间 ， 这 个 类 主要 用 于 DateTime 的 add/sub/diff 方 法。 
有 两 个 方法 得 到 DateInterval 对 象 : 


(1) 第 一 个 方法 是 使 用 构造 函数 ， 例 如 : 


构造 函数 接受 一 个 特殊 格式 的 字符 串 ， 用 P 开头 ， 然 后 以 数字 和 标识 符 来 表示 一 段 时 间 ， 
例如 1Y=1 年 。 如 果 有 时 分 秒 部 分 ， 则 加 一 个 T 在 时 分 秒 的 前 面 ， 例 如 PT1H。 
字符 串 格式 如 下 : 


， 也 可 以 用 W: 周 代替 


也 可 以 用 PY-m-dTH:i's 格式 传递 给 构造 函数 ， 例 如 : 


(2) 第 二 个 方法 是 使 用 静态 方法 createFromDateString， 传 入 的 字符 串 格式 为 strtotime 接受 
的 格式 ， 例 如 : 


获得 DateInterval 对 象 后 可 以 用 修改 它 的 公开 属性 来 修改 时 间 段 的 长 度 ， 例 如 : 
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DateInterval 的 公开 属性 有 y、m、d、h、i、s， 含 义 分 别 为 年 月 日 时 分 秒 ， 都 是 整数 类 型 。 
DateInterval 还 有 一 个 方法 是 format， 返 回 指定 格式 的 字符 串 来 表示 这 个 时 间 段 ， 例 如 : 





5.8.5 ”DatePeriod 类 


DatePeriod 类 用 来 表示 一 组 相同 时 间 段 间隔 的 时 间 ， 说 起 来 好 抛 口 ， 请 看 下 面 示例 。 
【示例 5-4】 如 何 获得 从 2016 年 1 月 1 日 至 2016 年 12 月 31 日 每 个 星期 五 是 几 号 ? 





请 读者 自己 运行 一 下 这 上段 代码 ， 就 知道 2016 年 的 每 个 周末 了 。 
DatePeriod 也 可 以 指定 时 间 组 的 长 度 ， 例 如 : 
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设计 程序 时 ， 文 件 是 很 重要 的 操作 对 象 ， 故 而 在 PHP 学 习 时 ， 对 文件 和 目录 进行 操作 的 函 
数 非常 常用 。 但 反 过 来 ， 一 旦 操作 失误 ， 常 常会 造成 严重 的 后 果 ， 一 定 要 了 解 清楚 再 用 。 
在 本 章 我 们 将 会 讲 到 : 


打开 文件 : fopen()。 

检查 是 否 已 到 达 文件 末尾 : feoft)。 

读 取 文件 : fread()。 

关闭 文件 : fclose()。 

将 整个 文件 读 入 一 个 字符 串 : file_get_contents()。 
将 字符 串 写 入 文件 : file_put_contents()。 
将 整个 文件 读 入 一 个 数组 : file0。 
复制 文件 : copy0。 

重 命名 文件 或 目录 : rename()。 

删除 文件 :unlink0。 

检查 文件 是 否 正常 : i。s _file()。 

检查 文件 或 目录 是 否 存在 : file_exists()。 
返回 关于 文件 的 信息 : stat()。 

打开 目录 : opendir()。 

关闭 目录 : closedir()。 

读 取 目 录 : readdir0。 

创建 目录 : mkdir()。 

删除 目录 : rmdir()。 


名. 1 文件 操作 


6.1.1 打开 文件 
fopen() 函数 的 作用 是 打开 文件 。 它 的 语法 结构 如 下 : 
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fopen (filename,mode) 
fopen (文件 名 或 URL, 打开 模式 ) 


以 上 两 个 参数 都 是 必需 的 。 其 中 “打开 模式 ”可 以 用 如 表 6.1 所 示 的 几 种 方式 。 
表 6.1 文件 的 打开 模式 














打开 模式 ”意义 说 明 
吧 只 读 只 读 方式 打开 文件 ， 将 文件 指针 指向 文件 头 
TH 读 写 读 写 方式 打开 文件 ， 将 文件 指针 指向 文件 头 
写 入 写 入 方式 打开 文件 ， 将 文件 指针 指向 文件 头 
如 果 文 件 已 存在 ， 将 其 清空 ， 如 果 不 存 在 ， 则 尝试 创建 
i 读 写 读 写 方式 打开 文件 ， 将 文件 指针 指向 文件 头 。 
如 果 文 件 已 存在 ， 将 其 清空 ， 如 果 不 存 在 ， 则 尝试 创建 
上 添加 写 入 方式 打开 文件 ， 将 文件 指针 指向 文件 末尾 。 如 果 文 件 不 存在 ， 则 尝试 创建 
at" 添加 读 写 方式 打开 文件 ， 将 文件 指针 指向 文件 末尾 。 如 果 文 件 不 存在 ， 则 尝试 创建 
以 写 入 方式 打开 文件 ， 将 文件 指针 指向 文件 头 。 如 果 文 件 已 存在 ， 则 fopen0) 调 
wn 谨慎 写 入 用 失败 返回 false， 并 生成 警告 
此 选项 被 PHP 4.3.2 以 及 以 后 的 版 本 所 支持 ， 仅 能 用 于 本 地 文件 
以 读 写 方式 打开 文件 ， 将 文件 指针 指向 文件 头 。 如 果 文 件 已 存在 ， 则 fopen0 调 
HH 谨慎 写 入 用 失败 返回 false， 并 生成 警告 
此 选项 被 PHP 4.3.2 以 及 以 后 的 版 本 所 支持 ， 仅 能 用 于 本 地 文件 
"en 创建 并 写 入 | 以 写 入 方式 打开 文件 ， 将 文件 指针 指向 文件 头 。 即 使 文件 存在 也 不 会 失败 或 清空 
ncH" 创建 并 读 写 | 以 读 写 方式 打开 文件 ， 将 文件 指针 指向 文件 头 。 即 使 文件 存在 也 不 会 失败 或 清空 





fopen0) 成 功 时 返回 文件 指针 资源 ， 如 果 打开 失败 ， 则 返回 false。 


$file = fopen('new.txt', 'r'); 
Snetwork = fopen('http://www.baidu.com'); 


6.1.2 ”检查 是 否 已 到 达 文 件 末 尾 


feofO 函 数 用 来 测试 文件 指针 是 否 到 了 文件 结束 的 位 置 ， 对 遍历 长 度 未 知 的 数据 非常 有 用 。 
它 的 语法 结构 是 : 


feof (file pointer) 
feof (文件 指针 ) 


如 果 文 件 指针 到 了 EOF (end of rile) 或 者 出 错 返 回 tue， 和 否则 返回 一 个 错误 〈 包 括 socket 
超时 ) ， 其 他 情况 则 返回 false。 








文件 指针 必须 是 有 效 的 ， 必 须 指向 由 fopen() 或 fsockopen() 成 功 打开 的 文件 (并 还 没有 被 
felose0) 关 闭 )。 如 果 服 务 器 没有 关闭 由 fsockopen() 所 打开 的 链接 ，feofD) 会 一 直 等 到 超时 返 
| 回 tue。 默 认 的 时 间 是 60 秒 ， 可 以 用 stream_set timeout() 来 改变 这 个 值 。 
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6.1.3” 读 取 文件 
fread() 函 数 可 以 读 取 文件 ， 对 二 进 制 文件 也 是 安全 的 。 它 的 语法 结构 如 下 : 





以 上 两 个 参数 都 是 必需 的 。“ 文 件 指针 ”从 fopen0 的 返回 值得 到 。 
fread() 从 指定 要 读 取 的 文件 读 取 指定 数量 的 字 节 。 返 回 的 是 所 读 取 的 字符 串 ， 如 果 出 错 则 返 
回 false。 


【示例 6-1】 


如 果 能 实际 读 取 的 文件 长 度 比 指定 长 度 短 ， 也 就 是 会 遇 到 EOF 的 情况 ， 函 数 也 会 自动 停 
止 ， 返 回 所 读 取 的 字符 串 。 


6.1.4 关闭 文件 
fclose0 函 数 用 来 关闭 打开 的 文件 。 它 的 语法 结构 是 : 


如 果 执 行 成 功 ， 函 数 返 回 tue， 和 否则 返回 false， 例 如 : 


画 用 完 文件 后 把 它们 关闭 是 一 个 良好 的 编程 习惯 ， 否 则 它们 会 继续 占用 服务 器 资源 。 
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6.1.5 将 整个 文件 读 入 一 个 字符 串 
file_get_contents0 可 以 把 整个 文件 读 入 一 个 字符 串 中 。 它 的 语法 结构 是 : 


如 果 函 数 正常 运行 ， 返 回 值 为 文件 内 容 ， 如 果 失 败 ， 返 回 False。 


6.1.6 将 字符 串 写 入 文件 


和 file_get_contents() 相 反 ，file_put_contents() 函数 可 以 把 一 个 字符 串 写 入 文件 中 。 它 的 语法 
结构 是 : 


其 中 ，“ 写 入 文件 ”参数 是 必需 的 。 如 果 该 文件 不 存在 ， 则 程序 自动 创建 一 个 新 文件 ， “要 
写 入 数据 ”参数 可 以 是 字符 串 、 数 组 、 数 据 流 等 , “打开 / 写 入 文件 方式 ”也 是 可 选 参数 ， 支 持 
3 种 方式 ， 如 表 6.2 所 示 。 


表 6.2 打开 / 写 入 文件 方式 


在 include_path 目录 里 搜索 要 写 入 的 文件 名 
如 果 要 写 入 文件 已 存在 ， 追 加 数据 而 非 禾 盖 
在 写 入 时 获得 一 个 独占 锁 


如 果 函 数 正常 运行 ， 返 回 写 入 到 文件 内 数据 的 字 节 数 ; 如 果 失 败 ， 返 回 false。 


【示例 6-2】 写 入 文件 。 





以 上 代码 也 可 以 简化 为 一 行 : 


10: 


CD 
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6.1.7 ”将 整个 文件 读 入 一 个 数组 
file( 可 以 把 整个 文件 读 入 一 个 数组 中 。 它 的 语法 结构 是 : 


如 果 函 数 正 常 运行 ， 返 回 值 为 数组 ， 数 组 元 素 由 文件 的 换行 键 分 隔 ， 如 果 失 败 ， 返 回 
false。 


读 取 参 数 为 可 选 参数 ， 其 值 列表 参见 表 6.3。 
表 6.3 读 取 参数 


常量 值 含义 


在 include_path 中 查找 文件 


在 数组 每 个 元 素 的 末尾 不 要 添加 换行 符 


例如 : 





file 函数 极为 实用 ， 因 为 无 须 打 开 / 读 取 /关闭 文件 ， 就 可 以 方便 地 读 取 整 个 文件 ， 然 后 进行 处 
理 ， 但 是 需要 注意 的 是 处 理 大 文件 ， 因 为 file 函数 是 将 文件 读 取 到 内 存 中 ， 会 占用 大 量 系统 
内 存 。 





6.1.8 复制 文件 
copy0 函 数 可 以 复制 文件 。 它 的 语法 结构 是 : 


以 上 参数 都 是 必需 的 。 如 果 函 数 成 功 执行 ， 则 返回 tue， 和 否则 返回 false， 例 如 : 


蝇 如 果 目 标 文件 已 存在 ， 将 会 被 完全 窗 盖 ， 一 定 要 谨慎 操作 。 
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6.1.9 删除 文件 
unlink() 函 数 用 来 删除 文件 。 它 的 语法 结构 是 : 


如 果 函 数 执行 成 功 ， 返 回 true; 执行 失败 ， 则 返回 false。 


6.1.10 ”检查 文件 是 否 正常 
is_file() 函 数 用 来 检查 指定 的 文件 名 是 否 是 正常 的 文件 。 它 的 语法 结构 是 ; 


如 果 要 检查 的 文件 存在 且 正常 ， 则 返回 true; 否则 返回 false， 例 如 : 


is_file 与 file_exists 的 区 别 是 is_file 只 检查 文件 ， 而 file _exists 既 检查 文件 也 检查 目录 。 





6.1.11 返回 关于 文件 的 信息 
stat0 函 数 用 来 返回 文件 的 统计 信息 。 它 的 语法 结构 是 : 


如 果 函 数 执行 成 功 ， 则 返回 包含 有 文件 的 统计 信息 的 数组 ， 和 否则 返回 false， 并 且 发 出 一 条 
返回 数组 说 明 参 见 表 6.4。 
表 6.4 返回 数组 说 明 





0 dev device number - 设备 名 
| 1 ino inode 号 码 | 
[2 








i inode 保护 模式 | 
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( 续 表 ) 
说 明 
number of links- 被 连接 数目 
userid of owner -所 有 者 的 用 户 id 
groupid of owner- 所 有 者 的 组 id 
设备 类 型 ， 如 果 是 inode 设备 
文件 大 小 的 字 节 数 
time of last access -上 次 访问 时 间 (Unix 时 间 戳 ) 
mti time of last modification- 上 次 修改 时 间 〈Unix 时 间 戳 ) 
time of last change- 上 次 改变 时 间 (Unix 时 间 戳 ) 


| blocksize of filesystem- 文 件 系统 IO 的 块 大 小 
所 占据 块 的 数目 





注意 ，rdev 在 Windows 下 总 是 0; 而 11 blksize 仅 在 支持 st_blksize 类 型 的 系统 下 才 有 效 ， 
其 他 系统 (如 Windows) 则 返回 -1， 例 如 : 
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.2 目录 操作 


6.2.1 打开 目录 
目录 ， 也 可 以 理解 为 文件 夹 。opendir0) 函 数 用 来 打开 一 个 目录 。 它 的 语法 结构 是 : 


如 果 执 行 成 功 ， 则 该 函数 返回 一 个 目录 句柄 ， 否 则 返回 false， 例 如 : 


如 果 要 打开 的 目录 路 径 不 合法 或 因为 权限 限制 或 文件 系统 错误 不 能 打开 ， 函数 会 返回 false 


及 一 条 错误 信息 。 如 果 要 隐藏 ， 可 以 在 opendir0 前 面 加 上 “@” 符 号 。 





6.2.2 关闭 目录 
closedir0 函 数 关闭 由 opendin() 函数 打开 的 目录 句柄 。 它 的 语法 结构 是 : 


要 关闭 的 目录 句柄 必须 之 前 由 opendir() 所 打开 。 ee re et] 系统 会 默认 为 
ee re et] 开 的 最 后 一 个 句柄 。 

















6.2.3 读 取 目录 
readdir() 函 数 返 回 由 opendir0 打 开 的 目录 句柄 中 的 条 目 。 它 的 语法 结构 是 : 
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如 果 执 行 成 功 ， 返 回 目录 中 下 一 个 文件 的 文件 名 ; 否则 返回 false。 
使 用 opendir、closedir、readdir 可 以 对 一 个 目录 下 的 文件 和 子 目 录 进 行 遍历 。 


【示例 6-3】 打印 当前 目录 下 的 所 有 文件 名 称 。 





6.2.4 创建 目录 
mkdir() 函 数 可 以 创建 目录 。 它 的 语法 结构 是 : 





成 功 时 返回 tme， 失 败 时 返回 false， 例 如 : 


在 Linux 和 Mac OSX 操作 系统 可 以 指定 mode 参数 ， 默 认 值 为 0777〈 八 进 制 表示 的 整 
数 ) ， 用 来 指定 目录 的 访问 / 读 写 权 限 ， 在 Windows 上 mode 参数 没有 作用 ， 例 如 : 


recursive 参数 用 来 控制 创建 目录 的 时 候 是 否 同时 创建 父 目录 ， 例 如 想 要 创建 testdivdirl， 此 
时 如 果 testdir 也 没有 建立 ， 则 使 用 recursive 参数 十 分 方便 ， 例 如 : 
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6.2.5 删除 目录 
mdir0 函 数 可 以 删除 目录 。 它 的 语法 结构 是 : 


成 功 时 返回 tue， 失 败 时 返回 包 lse， 例 如 : 


函数 会 尝试 删除 指定 的 目录 ， 但 该 目录 必须 是 空 的 ， 而 且 要 有 相应 的 权限 。 失 败 时 会 产生 一 
个 E_WARNING 级 别 的 错误 。 


6.2.6 ” 重 命名 文件 或 目录 
rename() 函 数 可 以 重 命名 文件 或 目录 ， 它 可 以 用 来 移动 文件 。 它 的 语法 结构 是 : 


如 果 函 数 执行 成 功 ， 返 回 true; 如 果 失 败 ， 则 返回 false， 例 如 : 


6.2.7 ”检查 文件 或 目录 是 否 存 在 
file_exists() 函 数 可 以 检查 文件 或 目录 是 否 存在 。 它 的 语法 结构 是 ; 


如 果 指 定 的 文件 或 目录 存在 ， 则 返回 true; 和 否则， 返回 false。 
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4PHP 与 国际 化 > 








国际 化 很 重要 ， 因 为 PHP 语言 是 针对 英语 开发 的 ， 后 来 才 增 加 了 国际 化 的 支持 。 中 文字 符 编码 
以 前 用 的 是 国标 ， 如 GB2312、GBK 等 ， 现 在 都 用 UTF-8。PHP 的 国际 化 模块 主要 有 两 个 : 

@ mb_string: 多 字 节 字符 串 模块 。 

@ intl: 国际 化 模块 。 

















多 字 节 字符 函数 


mb_string 模块 专门 处 理 多 字 节 字符 串 ，PHP 的 字符 串 函 数 大 多 都 是 针对 ASCII 字符 的 ， 因 
此 处 理 多 字 节 字符 串 时 结果 常常 不 准确 ， 例 如 : 


echo strlen(' 中 '); // 输 出 : 3 
echo mb_strlen(' 中 '); // 输 出 : 1 


因为 在 字符 串 一 章 中 已 经 介绍 过 一 些 函 数 ， 现 在 把 mb_string 的 对 应 函数 列举 在 这 里 ， 参 见 
ls 


表 7.1 mb_string 的 对 应 函数 
字符 串 函数 ”多 字 节 字符 串 函数 。 说 阴 


















































split mb _split 分 割 字符 串 

stripos mb _stripos 查找 字符 串 在 另 一 个 字符 串 首次 出 现 位 置 ， 大 小 写 不 敏感 

stristr mb_stristr 查找 字符 串 在 另 一 个 字符 串 首次 出 现 并 返回 部 分 字符 串 ， 
大 小 写 不 敏感 

strlen mb _strlen 获取 字符 串 长 度 

strpos mb _strpos 查找 字符 串 在 另 一 个 字符 串 首次 出 现 位 置 

strrchr mb _strrchr 查找 字符 在 另 一 个 字符 串 最 后 一 次 出 现 并 返回 部 分 字符 串 

strrichr mb_strrichr 查找 字符 在 另 一 个 字符 串 最 后 一 次 出 现 并 返回 部 分 字符 串 
大 小 写 不 敏感 

strripos mb_strripos 查找 字符 串 在 另 一 个 字符 串 最 后 一 次 出 现 的 位 置 ， 大 小 写 不 敏感 

strrpos mb _strpos 查找 字符 串 在 另 一 个 字符 串 最 后 一 次 出 现 的 位 置 

strstr mb _strstr 查找 字符 串 在 另 一 个 字符 串 里 首次 出 现 并 返回 部 分 字符 串 
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( 续 表 ) 




















7.1.1 检测 字符 串 的 编码 
mb_detect_encoding 可 以 检测 字符 串 的 编码 ， 例 如 : 





可 以 以 字符 串 或 数组 方式 指定 需要 检测 的 编码 ， 例 如 : 





7.1.2 ”检查 字符 串 在 指定 的 编码 里 是 否 有 效 
mb_check_encoding 可 以 检查 字符 串 在 指定 的 编码 里 是 否 有 效 ， 例 如 : 





7.1.3 ”转换 字符 编码 格式 
mb_convert_encoding 可 以 转换 字符 编码 格式 ， 例 如 : 


第 二 个 参数 用 来 指定 要 转换 的 编码 格式 。 

第 三 个 参数 用 来 指定 字符 串 的 编码 格式 ， 可 以 省 略 ， 也 可 以 是 字符 串 或 数组 形式 供 
mb_convert_encoding 函数 来 检测 字符 串 的 编码 格式 。 

这 个 函数 常用 于 GBK 编码 的 字符 串 转换 为 UTF-8 编码 ， 好 在 浏览 器 中 显示 ， 因 为 现在 的 浏 
览 器 和 操作 系统 都 支持 UTF-8 编码 ， 而 对 于 GBK 则 需要 额外 安装 软件 才 行 。 
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7.1.4 解析 $_GET 字符 串 
mb_parse_str 用 于 解析 $_GET 字符 串 ， 将 它 转换 为 一 个 数组 。 
【示例 7-1】 


| 
压 


7.1.5” 按 字 节 数 来 截取 字符 串 


mb_streut 与 mb_substr 类 似 ， 都 是 获取 部 分 字符 串 ， 不 一 样 的 是 mb_strcut 是 按 字 节 数 来 截 
取 的 ， 如 果 指定 的 长 度 刚好 位 于 一 个 多 字 节 字符 的 中 间 ， 则 从 这 个 字符 的 第 一 个 字 节 截取 ， 因 此 
mb_strcut 返回 的 字符 串 有 可 能 小 于 指定 的 长 度 ， 例 如 : 





mb_strcut 的 语法 结构 如 下 : 





$str: 需要 截取 的 字符 串 。 

$start: 开始 截取 的 起 始 位 置 ， 以 字 节 为 单位 。 

S$length: 需要 截取 的 长 度 ， 以 字 节 为 单位 ， 如 果 省 略 则 截取 剩余 所 有 字符 。 
$encoding: 字符 囊 的 编码 。 
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了 .2 intl 模块 简介 


intl 模块 是 一 个 ICU 库 的 封装 模块 ，ICU 库 是 一 个 C++ 类 库 ， 提 供 了 各 种 支持 国际 化 的 类 ， 
列表 如 下 : 
@ Collator: 提供 字符 串 比较 和 排序 功能 。 
NumberFormatter: 数字 格式 化 和 字符 串 解析 成 数字 。 
MessageFormatter: 字符 串 格式 化 功能 。 
IntlDateFormatter: 日 期 时 间 格式 化 。 
Normalizer: 将 字符 串 转换 为 Unicode 规范 格式 。 
Locale: 获取 区 域 信息 。 
Calendar: 日 历 操作 。 
TimeZone: 时 区 信息 。 


由 于 本 书 篇 幅 所 限 ， 下 面 对 部 分 类 进行 简单 介绍 ， 有 需要 详细 了 解 的 读者 请 参阅 官方 文档 。 


7.2.1 安装 intl 模块 

XAMPP 已 经 带 了 编译 好 的 intl 模块 ， 但 是 默认 情况 下 没有 安装 ， 因 此 需要 修改 php.ini 文件 
安装 intl 模块 ， 步 又 如 下 : 

(1) 打开 php.ini 文件 ， 找 到 如 下 一 行 : 

?extension=php intl1.d1ll 


php.ini 文件 可 以 在 安装 文件 夹 C:\xampp\php 下 找到 ， 也 可 以 通过 XAMPP 控制 面板 打开 
( 单 击 Apache 后 面 的 Config 按钮 ) ， 如 图 7.1 所 示 。 























回 xAMpp Control Panel v322 [Compiled: Nov 12th 2015] [= | © lm 
XAMPP Control Panel v3.2.2 [Leom ] | 
Se Wonle piDls) Portls) Actions 纺 ttn, nt 
spache J ,443 [i en 

MySQL Start Admin 


6 Apache (httpd-ssLconf) 
Som |[6 Apache (httpd-xampp.conf) 


[EH] 
Ea| 
vereury mm | gl © 


phpMyAdmin (configincphp) 
| 





Tomeat 
Browse> [Apache] 
er start Apache app... <Browse> 
se detected: running le 
0 stop Apache (PID: 5536) ston en ctuione, 


0 stop Apache (PID: 2028) 


0 start Apache app... 上 



































7.1 打开 php.ini 
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(2) 删除 最 前 边 的 分 号 ， 保 存 文件 。 此 时 ，int 模块 安装 完成 。 
重新 启动 Apache 服务 器 ， 打 开 浏 览 器 查看 phpinfp， 界 面 如 图 7.2 所 示 。 


intl 























7.2 安装 好 int 模块 


7.2.2 ”Collator 类 比较 字符 串 
Collator 类 用 来 比较 两 个 字符 串 。 
【示例 7.2】 比 较 字符 串 。 





以 上 代码 按照 中 文 顺序 对 数组 进行 排序 ， 输 出 : 





有 兴趣 的 读者 可 以 试 试 使 用 其 他 的 办 法 进行 排序 ， 看 看 是 否 有 更 好 的 方法 。 


7.2.3 _ NumberFormatter 类 帮助 做 财务 
NumberFormatter 这 个 类 有 个 特殊 的 用 途 ， 例 如 : 
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输出 : 


只 需要 再 做 一 下 替换 就 是 财务 记 账 的 数字 了 。 
【示例 7-3】 财 务 记 账 。 





输出 : 
齐全 葵 全 
有 兴趣 的 读者 可 以 在 网 络 上 找 找 这 是 不 是 最 简单 的 人 民 币 大 写 转换 代码 ? 


7.2.4 IntIDateFormatter 类 显示 中 文 版 的 日 期 时 间 
IntlDateFormatter 这 个 类 也 有 些 用 处 ， 可 以 显示 中 文 版 的 日 期 时 间 ， 例 如 ， 


输出 : 





IntlDateFormatter 定义 了 一 些 时 间 日 期 格式 ， 例 如 : 


FULL: 全 格式 ,例如 ，2016 年 1 月 1 日 星期 五 中 国标 准时 间 上 午 7:00:00。 
@ LONG: 长 格式 ,例如 ，2016 年 1 月 1 日 GMT+8 上 午 7:00:00。 

@ MEDIUM: 中 长 格式 ， 例如，2016 年 1 月 1 日 上 午 7:00:00。 

@ ”SHORT: 短 格式 ， 例如: 16/1/1 上 午 7:00。 


一 如 果 使 用 时 间 日 期 模块 ， 也 可 以 输出 类 似 的 格式 ， 但 可 能 要 多 写 一 点 代码 。 
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PHP 不 仅 可 以 输出 HTML， 还 可 以 输出 压缩 文件 ， 也 可 以 创建 和 操作 压缩 文件 。 本 章 主要 


讲述 比较 流行 的 zip 文件 格式 。 
在 PHP 中 通过 zip 模块 提供 了 可 以 读 取 zip 文件 的 函数 ， 也 提供 了 全 能 的 ZipArchive 类 。 


咏 . 1 zip 函数 


为 了 测试 zip 函数 ， 我 们 先 新 建 一 个 zip 文件 ， 笔 者 使 用 免费 的 7-zip， 将 cxxampp 7\htdocs 
中 的 文件 制作 成 htdocs.zip， 从 7-zip 中 可 以 看 到 文件 内 容 ， 如 图 8.1 所 示 。 





国 CYampp7\ntdocszlphtdocs\ 
文件 ( 鲍 外 (查看 (V) 书签 (A) 工 呈 (D 关 助 (HH 











中 

Wn 要 让利 下 动员 味 信 息 

| CYampp7\htdocszip\htdocs\ 

EE Em 一 盐 区 时 间 ”全 直 时间 ”访问 中间 CE CRC 划 计 
dashboard 10 1074- 7192357 2016-02_ Dp - 
mg 1088 。 1088 2013-11- D 56755EOF Store 
下 weballzer 0 2015-07- D 

xampp 34 34 2016-02- D BOB728,. Store| 
Oapplicatone nim 3845 1480 2016-02- A CF72B6F8 

站 phnamicss 1 122 2015-.07- A Cc 
fameonieo 30894 10968 2015-07- A Eg9F6272 
indexphp 260 185 2015-07- A 











8.1 压缩 的 文件 内 容 





8.1.1 打开 和 关闭 zip 文件 
使 用 zip_open 函数 打开 zip 文件 ，zip_close 函数 关闭 打开 的 zip 资源 句柄 ， 例 如 : 
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zip_open 和 zip_close 函数 语法 如 下 : 


成 功 的 时 候 返回 一 个 资源 句柄 供 函 数 zip_read0 和 zip_close0 后 续 使 用 ， 如 果 文件 不 存在 或 者 
出 现 其 他 错误 ， 则 会 返回 相应 的 错误 码 。 


8.1.2 读 取 并 打印 文件 /目录 名 称 


zip 文件 中 是 目录 和 文件 的 混合 ， 因 此 我 们 打开 zip 文件 后 需要 用 一 组 zip_entry 函数 来 做 实 
际 的 工作 。 


【示例 8-1】 读 取 并 打印 文件 。 


当前 操作 文件 夹 下 必须 有 一 个 htdocszip 压缩 包 ， 否 则 会 提示 出 错 。 





以 上 代码 输出 : 





zip_read 函数 读 取 zip 存档 文件 中 的 下 一 项 ， 成 功 时 返回 一 个 资源 可 以 进一步 处 理 ， 如 果 没 
有 下 一 项 ， 则 返回 false。 


Ey vg 
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8.1.3 ”处理 zip 文件 
以 下 一 组 函数 用 于 处 理由 zip_read 返回 的 zip_entry 项 : 
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Zip_entry_close: 关闭 zip_entry 项 。 

Zip_entry_compressedsize: 获取 zip_entry 项 压缩 过 后 的 大 小 。 
zip_entry_ compressionmethod: 获取 zip_entry 项 的 压缩 方法 。 
Zip_entry_filesize: 获取 zip_entry 项 的 实际 大 小 。 
Zip_entry_name: 获取 zip_entry 项 的 名 称 。 

Zip_entry_open: 打开 用 于 读 取 的 zip_entry 项 。 
Zip_entry_read: 读 取 一 个 打开 了 的 压缩 zip_entry 项 。 


【示例 8-2】 以 下 代码 将 htdocs.zip 解压 缩 到 当前 目录 下 的 子 目录 htdocs 中 。 
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以 上 代码 输出 : 


读 完了 以 上 的 代码 ， 读 者 应 该 比较 了 解 zip_entry 函数 的 用 法 了 ， 现 在 告诉 大 家 一 个 “好 消 
息 ”， 以 上 几 十 行 代码 可 以 用 以 下 代码 实现 : 
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你 说 牛 不 牛 ? ZipArchive 类 太 强 大 了 ! 


只 ,2 处 理 zip 文件 的 必 杀 技 : ZipArchive 类 


ZipArchive 确实 是 处 理 zip 文件 的 必 杀 技 ， 全 能 型 选手 ， 创 建 、 增 加 、 修 改 、 删 除 、 解 压 等 
方法 应 有 尽 有 。 
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打开 /关闭 压缩 文件 


ZipArchive 的 初始 化 函数 无 须 参数 ， 因 此 新 建 一 个 ZipArchive 对 象 十 分 简单 ， 例 如 : 


open 方法 打开 一 个 压缩 文件 ， 语 法 如 下 : 


成 功 打开 返回 tue， 和 否则 返回 错误 代码 。 打 开 模 式 参数 可 选 ， 混 合 使 用 以 下 预定 义 常量 : 


ZipArchive::CREATE: 如 果 不 存在 ， 则 创建 一 个 zip 压缩 包 。 
ZipArchive::OVERWRITE: 如 果 不 存在 ， 则 创建 一 个 zip 压缩 包 ; 如 果 存 在 ， 则 覆盖 。 
ZipArchive::EXCL: 如 果 压缩 包 已 经 存在 ， 则 出 错 。 

ZipArchive::CHECKCONS: 对 压缩 包 执行 额外 的 一 致 性 检查 ， 如 果 失 败 ， 则 显示 错误 。 


福 
对 
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8.2.2 ”解压 缩 文件 
extractTo 方法 用 来 解压 缩 文件 ， 语 法 如 下 : 


成 功 时 返回 TRUE， 失 败 时 返回 FALSE， 例 如 : 





8.2.3 添加 目录 与 文件 
用 addEmptyDir 方 法 添加 一 个 空 目录 ， 例 如 : 





有 多 个 方法 可 以 向 zip 压缩 文件 中 添加 文件 。 
1. addFile 添加 一 个 文件 
语法 如 下 : 
adgFile ( string 文件 名 [，string 蔡 换 文人 IJ]) 


例如 : 


用 7-zip 打开 testzip， 如 图 8.2 所 示 。 
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国 Cyampp7\htdocsvtestzipvdashboard\ 一 百 
文件 (F) 辆 辑 ( 昌 查看 (V) 书 答 (A) 工 RD 帮助 (H) 
入 中 中 XX 六 
添 10 提取 测试 复制 移动 删除 信息 
让 | Cyampp7\htdocs\testzip\dashboard\ ~ 
名 称 大 小 让 给 岳 大 -- 修改 时 间 。 创建 时 间 。 访问 时 间 后 全 
Oindecntml 6903 。 2325 2016-02.. 
Oindexlhtml 6903 。 2325 2016-02.. 
CE > 
选 定 0 个 项 目 
图 8.2 压缩 包 内 容 
2. addFromString 添加 一 个 指定 内 容 的 文件 


例如 : 


3. addGlob 按照 匹配 模式 添加 多 个 文件 
语法 如 下 : 


其 中 匹配 模式 和 匹配 标记 参见 glob 函数 的 说 明 ， 在 这 里 举 几 个 例子 参考 : 


4. addPattern 按照 正则 表达 式 匹 配 添加 多 个 文件 
语法 如 下 : 


正则 表达 式 请 参考 相关 文档 ， 这 里 举 几 个 例子 参考 : 


使 用 addPattem 的 问题 是 它 将 文件 的 绝对 目录 都 添加 进去 了 ， 如 图 8.3 所 示 。 
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国 Cvampp7\htdocs\testzip\c ampp\htdocs\ 一 口 x 
文人 fF) 编辑 (B， 吉 看 (V) 书签 (A) 工具 (帮助 (H) 
和 中 
添加 提取 测 坛 复制 移动 便 除 信息 

| Campphtdocsvtestzip\cwamppAhtdocs\ Ed 
名 称 六 路， 记 浊 后 大 修 下 时间。 创建 时 间 访问 时 间 属性 人 
晶 helloworldphp 37 37 2016-01.. 

indexphp 267 188 2013-03.. 

是 "bphp 353424 。 76 955 2016-01.. 

量 btestphp 444 303 2016-02.. 总 
> 
选 定 0 个 项 目 





图 83 目录 也 一 起 压缩 


因此 常用 以 下 代码 添加 文件 : 


8.24 遍历 zip 文 件 
以 下 代码 实现 遍历 zip 文件 ， 并 打印 文件 名 称 。 
【示例 8-3】 遍历 zip 文件 。 





numFiles 属性 是 压缩 文件 中 的 文件 数量 ，getNameIndex 方法 返回 第 i 个 文件 的 名 称 。 
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8.2.5 ”获取 文件 


如 果 知道 文件 的 编号 ， 使 用 getFromIndex 方法 可 以 获取 指定 编号 的 文件 内 容 ， 例 如 : 


如 果 知 道 文件 名 ， 使 用 getFromName 方法 也 可 以 获取 文件 内 容 ， 例 如 : 





使 用 getStream 方法 可 以 获取 一 个 文件 指针 ， 然 后 使 用 文件 函数 如 fread 就 可 以 获取 文件 内 
容 ， 这 种 方法 可 以 节约 内 存 ， 适 合 处 理 大 文件 ， 例 如 : 





ZipArchive 的 方法 就 介绍 到 这 里 ， 有 兴趣 的 读者 请 参考 官方 文档 继续 学 习 。 





PHP 从 PHP 4 就 提供 了 处 理 图 像 的 扩展 库 GD， 利 用 这 个 库 ，PHP 就 可 以 生成 图 片 并 对 图 片 
进行 处 理 。PHP 7 依然 保留 了 GD 库 ， 版 本 是 GD2。 本 章 就 从 PHP 的 图 像 处 理 函 数 开始 ， 向 读 
者 介绍 如 何 通过 PHP 完成 图 像 处 理 。 


吕 . 1 启用 GD2 扩展 库 


我 们 可 以 找到 XAMPP 的 安装 文件 夹 “C:xampp\php\ext”， 找 到 php_gd2.dll， 说 明 在 PHP 
安装 的 时 候 已 经 自 带 了 GD2 库 ， 屠 我 们 就 可 以 直接 在 php.ini 中 启动 它 。 
打开 XAMPP， 单 击 Apache 后 面 的 Config 按钮 打开 php.ini， 可 通过 查找 “gd2” 的 方式 找到 


把 前 面 的 分 号 去 掉 ， 就 可 以 启动 GD2 了 ， 利 用 phpinfo.php 页 面 我 们 就 可 以 看 到 gd 的 一 些 
信息 ， 如 图 9.1 所 示 。 




































































目前 GD2 库 的 图 像 处 理 函数 有 上 百 个 ， 限 于 篇 幅 不 能 一 一 讲述 ， 本 节 将 向 读者 介绍 一 些 有 
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代表 性 的 图 像 处 理 函数 。 后 面 的 章节 中 ， 将 通过 小 例子 向 读者 演示 这 些 函 数 的 用 法 : 





resource imagecreateffomgiffstring $filename): 该 函数 用 来 从 给 定 的 GIF 文件 或 URL 取 
出 一 个 图 像 ， 参 数 $filename 是 文件 名 或 URL。 该 函数 返回 值 是 图 像 标 识 符 ， 代 表 了 从 
给 定 的 文件 名 取得 的 图 像 。 失 败 时 ， 返 回 一 空 字符 串 ， 并 且 输 出 一 条 错误 信息 。 

bool imagegifresource $image [, string $filename]): 该 函数 从 参数 $image 所 代表 的 图 像 以 
参数 $filename 为 文件 名 创建 一 个 GIF 图 像 。image 参数 是 imagecreate() 或 
imagecreatefromgif 等 函数 的 返回 值 。 

resource imagecreateffompng ( string $filename ): 该 函数 从 PNG 文件 或 URL 取出 一 个 图 
像 ， 参 数 $filename 是 文件 名 或 URL。 该 函数 返回 值 是 图 像 标识 符 ， 如 果 执 行 失败 ， 函 
数 返 回 一 个 空 字 串 ， 并 且 输 出 一 条 错误 信息 。 

bool imagepng(resource $image [, string $filename]): 该 函数 类 似 imagegif)， 将 GD 图 像 
流 (参数 $image 代表 ) 以 PNG 格式 输出 到 标准 输出 (通常 为 浏览 器 ) ， 或 者 如 果 用 参 
数 $filename 给 出 了 文件 名 ， 则 将 其 输出 到 该 文件 。 

resource imagecreate(int $x_size, int $y_size): 新 建 一 个 基于 调 色 板 的 图 像 ， 参 数 $x_size 
和 $y_size 代表 了 创建 图 像 的 宽 和 高 ， 该 函数 返回 所 创建 图 像 的 标识 符 。 

resource imagecreatetruecolor(int $x_size, int $y_size): 该 函数 返回 一 个 图 像 标识 符 ， 它 代 
表 了 一 幅 大 小 为 $x_size 和 $y_size 的 黑色 图 像 。 

int imagecolorallocate(resource $image, int $red, int $green, int $blue): 参数 Simage 是 图 片 
标识 符 ， 参 数 $red、$green、$blue 分 别 代表 色 系 中 的 红色 、 绿 色 和 蓝 色 (RGB ) ， 这 
些 参数 的 取 值 范围 是 0 到 255， 或 者 十 六 进 制 的 0x00 到 0xFF， 例 如 代码 
imagecolorallocate($img, 255, 0, 0) 表 示 设 置 图 像 $img 的 颜色 为 红色 。 该 函数 的 返回 值 代 
表 了 由 给 定 的 参数 组 成 的 颜色 。 

bool imagefill(resource $image, int $x, int $y, int $color): 该 函数 在 参数 $image 所 指定 图 像 
的 坐标 $x 和 $y ( 图像 左上 角 为 0，0) 处 用 $color 颜色 执行 区 域 填 充 ， 即 与 x，y 点 颜 
色相 同 且 相 邻 的 点 都 会 被 填充 。 

bool imageline(resource $image, int $x1, int $y1, int $x2, int $y2, int $color ): 该 函数 用 参数 
S$color 所 指定 的 颜色 在 参数 $image 所 标识 的 图 像 中 从 坐标 $x1，$yl 到 $x2，$y2 (图 像 
左上 角 为 0, 0 ) 画 一 条 线段 。 

bool imagestring(resource $image, int $font, int $x, int $y, string $s, int $col): 水 平地 显示 一 
行 字符 串 。 该 函数 用 参数 $col 所 指定 的 颜色 将 字符 囊 $s 显示 到 参数 $image 所 标识 图 像 
的 $x，$y 坐标 处 。 


名 . 2 创建 图 形 图 像 


前 面 已 经 了 解 了 PHP 有 图 像 库 ， 也 了 解 了 这 些 图 像 库 提供 了 哪些 函数 ， 本 节 开 始 了 解 PHP 
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创建 图 像 的 代码 和 步骤 。 


9.2.1 用 PHP 生 成 一 个 简单 图 形 
本 小 节 我 们 直接 做 一 个 图 形 的 例子 ， 读 者 先 了 解 GD2 库 的 使 用 。 


【示例 9-1】 生 成 一 个 方 框 。 


<?php 

header ('Content-Type: image/png'); // 疝 浏览 器 发 送 头 信息 ,输出 png 图 片 
S$width = 300; // 宽 度 

Sheight =300; // 高 度 


$img = imagecreatetruecolor ($width,$height) or die(" 不 支持 GD 图 像 处 理 
") ; ”// 创 建 图 形 


imagepng ($img); // 输 出 图 形 
imagedestroy ($img); ”// 清 除 资源 


函数 imagecreatetruecolor() 建 立 了 一 个 图 像 标 识 符 8img， 它 代 
表 了 一 个 黑色 图 像 ， 这 个 黑色 图 像 的 大 小 ， 由 变量 $width 和 S$height 
指定 。 函 数 imagepng(0 以 PNG 格式 生成 该 图 像 。 函 数 
imagedestroy() 清 除 绘制 图 像 时 所 占用 的 系统 资源 。 最 终 效 果 如 图 
9.2 所 示 。 


9.2.2 详解 PHP 生成 图 形 的 步骤 
在 PHP7 中 创建 一 个 图 形 通常 需要 4 步 : 


(1) 创建 一 个 背景 图 像 ， 后 面 的 操作 基于 此 背景 。 图 92 输出 一 个 默认 的 方形 
(2) 在 图 像 上 绘制 轮廓 或 者 输入 文本 。 

(3) 输出 图 形 。 

(4) 清除 资源 。 








这 里 以 前 面 示例 9-1 来 简单 说 明 下 。 要 在 PHP 中 创建 背景 图 像 ， 代 码 是 : 

resource imagecreatetruecolor ( int x size, int y size ) 

imagecreatetruecolor() 函 数 返 回 一 个 图 像 标识 符 ， 代 表 了 一 幅 大 小 为 x_size 和 y_size 的 黑色 
图 像 。 这 里 我 们 要 注意 ， 默 认 颜 色 为 黑色 ， 为 了 简化 代码 我 们 在 示例 9-1 采用 了 默认 颜色 。 

要 绘制 颜色 ，PHP 提供 了 Imagecolorallocate() 为 图 像 选择 颜色 。 颜 色 由 红 、 绿 、 蓝 (RGB) 
值 的 组 合 决定 。 该 函数 语法 如 下 : 


int imagecolorallocate ( resource image, int red, int green, int 
blue’ ) 
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接 下 来 ， 我 们 需要 使 用 其 他 函数 将 颜色 绘制 到 图 像 中 。 用 哪个 函数 取决 于 要 绘制 的 内 容 : 直 
线 、 弧 形 、 多 边 行 或 者 文本 。 我 们 介绍 下 常 使 用 的 三 个 函数 。 


® imagefill0 
bool imagefill ( resource image, int x int y, int color ) 


imagefill0 函 数 在 image 图 像 的 坐标 x，y (图像 左上 角 为 0.0) 处 用 color 颜色 执行 区 域 填充 
( 即 与 x，y 点 颜色 相同 且 相 邻 的 点 都 会 被 填充 ) 。 





























全 鳃 有 ”pp 国信 的 起 始 业 标 从 左上 角 开始 ， 该 点 坐标 为 X-0Y-0， 图 像 右 下 角 的 坐标 为 
, X=SwidthY=Sheight。 这 和 常规 做 图 习惯 是 相反 的 。 





imageline0 函 数 用 color 颜色 在 图 像 image 中 从 坐标 x1，yl 到 x2，y2〔 图 像 左上 角 为 0.0) 
画 一 条 线段 。 
@ imagestring() 


imagestring0 用 col 颜色 将 字符 串 s 画 到 image 所 代表 的 图 像 的 坐标 x，y 处 〈 这 是 字符 串 左 
上 角 坐 标 ， 整 幅 图 像 的 左上 角 为 0.0) 。 如 果 font 是 1，2，3，4 或 5， 则 使 用 内 置 字体 。 


民 却 如 果 font 字体 不 是 内 置 的 ， 则 需要 导入 字体 库 以 后 该 函数 才 可 正常 使 用 。 


创建 图 像 以 后 就 可 以 输出 图 形 或 者 保存 到 文件 中 ， 如 果 需 要 直接 输出 可 以 使 用 Header0 函 数 
来 发 送 一 个 图 形 头 来 欺骗 浏览 器 ， 使 它 认 为 运行 中 的 PHP 页面 是 一 幅 真 正 的 图 像 。 





发 送 标题 数据 后 ， 就 可 以 使 用 imagepng0 函 数 来 输出 图 像 数据 。 该 函数 的 使 用 语法 如 下 : 





最 后 务必 清除 创建 该 图 像 所 占用 的 内 存 资源 ， 语 法 如 下 : 
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名 .本 操作 图 形 图 像 


除了 用 PHP 创建 图 像 ， 我 们 还 可 以 对 图 像 进行 处 理 ， 本 节 通 过 简单 的 两 个 例子 : 更 改 图 像 
颜色 和 在 图 像 上 输出 文字 来 介绍 PHP 操作 图 形 图 像 的 一 些 方法 。 





9.3.1 更 改 图 像 颜色 


前 面 分 析 PHP 生成 图 形 的 步骤 时 ， 我 们 说 过 示例 9-1 简化 了 步 又， 默认 只 生成 了 黑色 图 
像 ， 其 实 可 以 用 imagecolorallocate0 函 数 来 更 改 图 像 的 颜色 。 


【示例 9-2】 更 改 图 像 颜色 。 





上 述 代码 通过 imagecolorallocate0 设 置 一 个 颜色 值 ， 然 后 用 imagefill0) 填 充 颜色 ， 最 终 效果 如 
图 9.3 所 示 。 





93 ”更 改 图 像 的 颜色 


9.3.2 ”在 图 像 上 输出 文字 
在 图 像 上 输出 文字 需要 使 用 imagestring0)， 其 语法 形式 是 : 


这 里 需要 指定 文字 的 字体 、 颜 色 、 位 置 和 内 容 。 
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【示例 9-3】 在 图 像 上 输出 文字 。 


PP 
口 localhost/9 空 | 三 








图 9.4 输出 文字 


日 .A 操作 已 有 的 图 片 


前 面 学 习 的 是 新 建 图 形 图 像 ， 并 在 这 个 新 建 图 形 图 像 的 基础 上 操作 。 那 么 ， 对 于 已 经 设计 好 
的 图 片 ， 我 们 如 何 打开 并 进行 操作 呢 ? 本 节 就 来 详细 介绍 。 


9.4.1 获取 图 片 的 宽 和 高 


要 获取 图 片 的 宽 高 属性 ， 我 们 先 使 用 imagecreatefromjpeg() 打 开 需 要 的 jpeg 格式 图 片 ， 并 指 
定 图 片 的 绝对 路 径 ， 默 认 路 径 是 PHP 工作 文件 夹 “C:xampp\htdocs”。 打 开 文件 后 ， 我 们 使 用 
imageSXO0 和 ImageSY() 获 取 宽 度 和 高 度 ， 如 图 9.5 所 示 。 


【示例 9-4】 
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图 片 的 宽 为 ，1024 
图 片 的 高 为 ，768 


图 95 获取 图 片 的 宽 和 高 


9.4.2 生成 图 片 的 缩 略图 


从 Windows 7 开始 ， 我 们 能 在 任务 栏 中 看 到 一 些 窗口 的 缩小 界面 ， 我 们 称 这 类 界面 为 缩 略 
图 ， 目 前 很 多 图 片 管理 软件 也 都 支持 缩 略 图 。 本 节 我 们 就 来 学 习 如 何 用 PHP 生成 缩 略 图 。 


【示例 9-5】 生成 图 片 的 缩 略 图 。 





从 代码 中 可 以 看 出 ， 首 先 要 打开 原 图 ， 然 后 获取 原 图 的 宽 和 高 ， 然 后 使 用 round0 计 算出 缩 
略图 的 宽 和 高 ， 然 后 创建 一 张 新 图 。 前 面 我 们 用 到 的 都 是 imagepng (0， 这 里 我 们 用 
imagejpeg()， 因 为 打开 的 是 jpeg 格式 的 图 片 。 本 例 效果 如 图 9.6 所 示 。 





图 9.6 生成 图 片 的 缩 略 图 
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9.4.3 ”给 图 片 添 加 水 印 效果 一 一 文字 水 印 
文字 水 印 估计 读者 一 看 就 明白 ， 就 是 给 原 有 的 图 片 添加 上 一 段 文 字 。 
【示例 9-6】 给 图 片 添加 文字 水 印 效果 。 





在 创建 文字 水 印 时 ， 注 意 先 设 计 好 文字 的 字体 (这 里 使 用 了 PHP 自 带 的 字体 ， 也 可 以 用 
Windows 带 的 一 些 字体 ， 指 定 字体 所 在 的 位 置 即 可 ) 和 颜色 ， 然 后 在 imagefttext0 中 填写 文字 的 
内 容 。 本 例 效果 如 图 9.7 所 示 。 





图 9.7 给 图 片 添加 水 印 〈 文 字 水 印 ) 


上 面 的 例子 我 们 只 支持 jpeg 格式 的 图 片 ， 如 果 要 支持 大 部 分 格式 〈 如 png) ， 可 以 更 改 这 段 
代码 为 : 
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到 像 处理 








9.4.4 给 图 片 添加 水 印 效果 一 一 图 片 水 印 


前 面 我 们 添加 了 文字 水 印 ， 本 节 再 来 添加 一 个 图 片 水 印 ， 一 般 用 于 添加 一 些 公司 的 
LOGO。 


【示例 9-7】 给 图 片 添加 图 片 水 印 效果 。 





PHP+MySQL 网 站 开发 


读者 可 以 参考 代码 的 注释 来 理解 这 段 代 码 ， 本 例 效果 如 图 9.8 所 示 。 





图 9.8 给 图 片 添加 水 印 
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第 10 
< 正则 表 认 式 > 


要 在 计算 机 系统 中 查找 某 个 文件 ， 碰 巧 忘记 了 文件 名 ， 但 知道 该 文件 的 类 型 ， 即 知道 该 文件 
的 后 级 名 ， 比 如 ， 要 找 一 个 图 片 ， 那 么 可 能 会 通过 *.png 这 样 的 字符 来 帮助 查找 ， 其 中 字符 * 就 代 
表 了 一 个 或 多 个 字符 。 计 算 机 通过 这 样 的 字符 组 合 ， 会 将 系统 中 所 有 以 .png 为 后 级 名 的 文件 列 出 
来 ， 如 : m.png、flag.png、river.png、mydog.png 等 ， 以 便 用 户 找到 需要 的 图 片 文件 。 

*png 就 是 一 个 表达 式 ， 我 们 可 以 简单 理解 为 正则 表达 式 (Regular expression) 。 正 则 表达 
式 是 一 种 可 以 用 于 模式 匹配 的 强大 工具 。 简 单 地 说 ， 正 则 表达 式 就 是 一 套 规则 ， 用 于 去 判定 其 他 
的 元 素 是 否 符合 它 。PHP 继承 了 Perl 的 正则 表达 式 法 则 ， 还 有 自己 的 一 套 法 则 。 本 章 将 详细 介 
绍 PHP 的 正则 表达 式 。 





在 PHP 中 使 用 正则 表达 式 


本 节 通 过 一 个 例子 让 读者 了 解 正则 表达 式 在 PHP 中 如 何 使 用 ， 以 及 PHP 中 有 关 正 则 的 函 
数 。 这 些 函 数 与 PHP 5 中 的 函数 不 同 ， 如 果 是 升级 PHP 代码 的 读者 请 务必 注意 ， 调 试 PHP 5 中 
的 正则 函数 会 报错 。 


10.1.1 应 用 正则 的 函数 


在 PHP 中 主要 有 3 个 函数 来 处 理 正则 表达 式 ， 用 来 检查 一 个 字符 串 是 否 满足 一 个 的 规则 。 
它们 都 把 一 个 正则 表达 式 作为 它们 的 第 一 个 参数 ， 语 法 为 : 


@ int preg_match(string $pattem , string $subjecb: 最 常用 的 正则 表达 式 函 数 ， 搜 索 跟 正则 
表达 式 pattem 匹配 的 一 个 字符 串 。 搜 索 到 返回 1， 和 否则 返回 0。 这 个 函数 在 PHP 5 中 
是 ereg()。 

@ string preg replace(mixed $pattem , mixed $replacement , mixed $subject): 搜索 跟 正 则 表 
达 式 pattern 匹配 的 一 个 字符 串 ， 并 用 新 的 字符 串 代 替 所 有 这 个 表达 式 出 现 的 地 方 ， 
PHP 5 中 是 replace()。 

@ array preg_split(string $pattern , string $subject) : 搜索 和 正则 表达 式 匹 配 的 字符 囊 ， 并 且 
以 字符 串 集合 的 方式 返回 匹配 结果 。 
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本 节 ， 旨 在 给 出 PHP 提供 的 正则 表达 式 函数 ， 并 简单 介绍 其 功能 。 


10.1.2 ”通过 一 个 例子 理解 正则 


举 一 个 简单 的 例子 : 在 一 个 用 户 注册 的 页 面 中 例如 ， 一 个 论坛 或 者 交友 网 站 的 注册 页 
面 )， 上 面 可 能 有 “电子 邮件 ”这 一 项 需要 填写 。 对 系统 来 说 ， 需 要 判定 用 户 所 填写 的 电子 邮件 
地 址 是 否 合法 ， 即 是 否 符合 电子 邮件 地 址 的 规则 。 


【示例 10-1】 未 使 用 正则 检测 电子 邮件 地 址 规则 。 





上 面 代码 实现 了 一 个 函数 validate_emaill()， 使 用 字符 串 操作 中 的 定位 字符 函数 ， 用 来 判断 
一 个 字符 串 是 否 是 一 个 合法 的 电子 邮件 地 址 。 仔 细 考 虑 实现 的 功能 ， 实 际 上 是 在 判断 一 个 字符 串 
是 否 具 有 一 定 的 模式 ， 或 者 说 是 否 满足 一 定 的 规则 。 在 这 种 情况 下 ， 就 可 以 使 用 正则 表达 式 来 实 
现 相 同 的 功能 。 


【示例 10-2】 使 用 正则 检查 电子 邮件 地 址 规则 。 





上 面 实现 了 有 具有 相同 功能 的 函数 validate emaill0 ， 函 数 使 用 了 一 个 正则 表达 式 的 函数 
preg_match()。 

观察 preg_match() 函 数 的 pattem 参数 可 以 看 出 ， 它 实际 上 表示 满足 这 样 规 则 的 字符 串 ， 以 任 
意 大 小 写字 符 串 (或 数字 ) 开头 ， 然 后 紧 跟 “@”， 然 后 又 是 任意 大 小 写字 母 (或 数字 ) 组 成 的 
字符 串 ， 最 后 的 i 表示 不 区 分 大 小 写 。 这 相当 于 定义 了 一 个 字符 串 的 组 成 规则 。 


第 10 章 正则 表达 式 


看 过 这 个 示例 后 ， 重 新 来 看 正则 表达 式 的 定义 : 正则 表达 式 是 一 种 可 以 用 于 模式 匹配 的 强大 
工具 。 





10.1.3 ”定义 正则 表达 式 的 头 部 和 尾部 

在 匹配 一 个 字符 串 到 正则 表达 式 之 前 ， 必 须 先 构造 正则 表达 式 。 构 造 时 要 遵循 一 定 的 规则 ， 
本 节 介绍 表达 式 头 部 和 尾部 的 定义 规则 。 

1. 定义 头 部 规则 

PHP 用 “^” 定义 字符 囊 头 部 的 规划， 例如: “^hello” 即 定义 头 部 为 “hello” 的 字符 串 ， 如 
代码 : 

<?php echo preg match ("/^hello/", "hello world!"); ?>//1 
将 返回 1， 因 为 待 验 证 的 字符 串 “hello word!” 满 足 规则 : 以 “hello” 开 头 。 而 
<?php echo preg match ("/^hello/", "i say hello world"); ?> //0 
将 返回 0， 因 为 hello 不 在 字符 串 “i say hello world” 的 头 部 。 





2. 定义 尾部 规则 
PHP 用 “$” 定 义 字符 串 尾 的 规则 ， 例 如 : “world$” 即 定义 尾部 为 “world” 的 字符 串 ， 如 代码 : 
<?php echo preg match("/world$/", "hello world!"); ?> A 


将 返回 1， 因 为 待 验证 的 字符 串 “hello word!” 满 足 规则 :以 “world” 结 尾 。 而 代码 
<?php echo preg match("/world$/", "i say hello php"); ?> //0 
将 返回 0， 因 为 world 不 在 字符 串 “i say hello php” 的 尾部 。 





1 0 .2 ”正则 表达 式 中 的 符号 


上 一 节 的 最 后 一 小 节 我 们 只 介绍 了 正则 表达 式 的 头 部 和 尾部 ， 用 ^ 来 表示 头 、$ 表 示 尾 ， 这 些 
符号 是 正则 表达 式 的 基本 符号 ， 我 们 称 之 为 元 符号 。 本 节 介绍 正则 表达 式 中 一 些 专用 的 符号 。 





10.2.1 元 字符 
正则 表达 式 中 的 元 字符 有 : ^$[]\.|?*+()， 下 面 分 别 介 绍 这 些 元 字符 的 用 途 。 
@ ^: 用 来 匹配 以 指定 字符 (或 字符 囊 ) 开头 的 字符 串 。 例 如 ， 模 式 ^hell 可 以 匹配 
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hello、hell 等 ， 但 不 匹配 holla。 
@ 美元 符号 $: 用 来 匹配 以 指定 字符 (或 字符 囊 ) 结尾 的 字符 囊 。 例 如 ，ow$ 可 以 匹配 
low、fellow 等 ， 这 些 字符 囊 均 以 ow 结尾 。 


这 些 单词 必须 以 字母 “b” 开 头 ， 以 “s” 字 母 结束 。 通 常 可 以 使 用 这 个 通配符 一 一 英 
文句 点 符号 “.”。 这 样 ， 完整 的 模式 就 是 “b.s”， 这 就 是 一 个 正则 表达 式 ， 它 可 以 匹 
配 的 三 个 字母 的 单词 ， 这 些 单词 可 以 是 “bes” “bis” “bos” 和 “bus”。 事 实 上 ,这 
个 正则 表达 式 还 可 以 匹配 “b3s”“b#s” 甚 至 “b s”， 还 有 其 他 许多 无 实际 意义 的 组 
合 。 又 如 ， 模 式 ^.5$ 匹 配 以 数字 5 结尾 和 以 其 他 非 换 行 字符 开头 的 字符 囊 。 模 式 .可 以 
匹配 任何 字符 串 ， 除 了 空 串 和 只 包括 一 个 换行 的 字符 囊 。 

@ 方 括号 []: 为 了 解决 句点 符号 匹配 范围 过 于 宽泛 的 问题 ， 可 以 用 方 括号 “[]” 来 指定 匹 
配 范围 ， 可 以 在 方 括号 内 指定 有 意义 的 字符 。 此 时 ， 只 有 方 括号 里 面 指 定 的 字符 才 参 
与 匹配 。 也 就 是 说 ， 正 则 表达 式 “b[eiou]s” 只 匹配 “bes”、 “bis”、 “bos” 和 
“bus”。 但 “bees” 不 匹配 ， 因 为 在 方 括 号 之 内 只 能 匹配 单个 字符 。 例 如 ，[a-z] 用 来 
匹配 所 有 小 写字 母 ， 但 只 能 匹配 一 个 字母 。 注 意 ， 通 常用 符号 -连接 匹配 范围 的 首尾 。 

@ 或 操作 符号 |; 可 以 完成 在 两 项 或 多 项 之 间 选 择 一 个 进行 匹配 。 对 于 上 述 的 例子 ， 如 果 
还 想 匹 配 “boos”， 那 么 以 使 用 “|” 操 作 符 ，“|” 操 作 符 的 基本 意义 就 是 “或 ” 运 
算 。 所 以 正则 表达 式 “b(aleliloloo)s” 可 以 匹配 “boos”。 特 别 注意 ， 这 里 不 能 使 用 方 
括号 ， 因 为 方 括 号 只 允许 匹配 单个 字符 。 这 里 必须 使 用 圆 括号 “()”。 辆 括号 还 可 以 用 
来 分 组 。 如 果 项 望 在 正则 表达 式 中 实现 类 似 编 程 逻辑 中 的 “或 ”运算 ， 在 多 个 不 同 的 
模式 中 任 选 一 个 进行 匹配 的 话 ， 就 可 以 使 用 元 字符 |。 

@ \: 用 来 转 义 一 个 字符 。 对 于 一 些 特殊 的 符号 的 匹配 ， 如 元 字符 本 身 和 空格 、 制 表 符 
等 ， 需 要 用 到 转 义 ， 所 有 的 转 义 序列 都 用 左 斜 杠 \ 打 头 。 例 如 ， 要 在 正则 表达 式 中 匹配 
元 字符 $， 就 需要 使 用 $， 匹 配 元 字符 \ 就 要 使 用 \\。 

@ (): 标记 一 个 子 表达 式 的 开始 和 结束 位 置 ， 即 括 住 一 个 表达 式 。 


以 上 介绍 的 元 字符 基本 可 以 看 作 是 对 字符 〈 或 字符 串 ) 位 置 的 匹配 ， 下 面 介绍 和 匹配 次 数 有 
关 的 一 些 元 字符 。 这 些 元 字符 用 来 确定 紧 靠 该 符号 左边 的 符号 出 现 的 次 数 。 注 意 ， 这 里 强调 了 
“ 紧 靠 左边 ”这 一 原则 。 


@ *; 匹配 其 左边 ( 即 前 面 ) 的 子 表达 式 0 次 或 多 次 。 例 如 ，pe* 匹 配 perl、peel、pet、 
port 等 ， 因 为 这 些 字符 串 都 符合 ( 即 匹配 ) 在 字母 p 后 连续 出 现 0 个 或 多 个 字母 e。 

@ +: 匹配 其 左边 ( 即 前 面 ) 的 子 表达 式 1 次 或 多 次 ， 注 意 ， 与 * 不 同 ，+ 前 的 字符 至 少 要 
出 现 1 次 ， 例 如 ，co+ 匹 配 come、code、cool、co 等 ， 这 些 字 符 串 都 匹配 在 字母 c 后 至 
少 出 现 1 个 或 多 个 字母 o。 

@ ?7: 匹配 其 左边 ( 即 前 面 ) 的 子 表达 式 0 次 或 1 次 。 











医 亏 *、+ 和 ?只 对 紧 挨 它 的 前 面 那个 字符 起 作用 。 
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10.2.2 ” 转 义 字符 


正则 表达 式 中 的 转 义 ， 除 了 需要 对 元 字符 转 义 之 外 ， 还 有 一 些 非 打印 的 字符 在 匹配 时 需要 转 
义 。 这 些 字 符 及 其 含义 见 表 10.1。 





表 10.1 转 义 含义 








匹配 由 x 指明 的 控制 字符 。 例 如 ，\eM 匹配 一 个 Control-M 或 回 车 符 。x 的 值 必须 是 A-Z 
或 a-z 之 一 ; 否则 ， 将 c 视 为 一 个 原 义 的 'c 字 符 ， 即 字符 c 本 身 








10.2.3 ”修正 符 


在 本 章 第 一 个 例子 中 ， 我 们 使 用 了 i 修正 符 来 忽略 大 小 写 ， 本 小 节 就 介绍 下 PHP 中 有 哪些 
修正 符 : 


@ i (PCRE_CASELESS) : 匹配 时 忽略 大 小 写 。 

@ m (PCRE MULTILINE ) : 当 设 定 了 此 修正 符 ， 行 起 始 (^) 和 行 结束 ($) 除 了 匹配 整个 字 
符 串 开头 和 结束 外 ， 还 分 别 匹配 其 中 的 换行 符 (m) 的 之 后 和 之 前 。 

@ s (PCRE DOTALL ) : 如 果 设 定 了 此 修正 符 ， 模 式 中 的 圆 点 元 字符 ( .) 匹配 所 有 的 字 
符 ， 包 括 换行 符 。 如 没有 此 设 定 的 话 ， 则 不 包括 换行 符 。 

@ x (PCRE_ EXTENDED ) : 如 果 设 定 了 此 修正 符 ， 模 式 中 的 空白 字符 除了 被 转 义 的 或 
在 字符 类 中 的 以 外 ， 完 全 被 忽略 。 

@ ce: 如 果 设 定 了 此 修正 符 ，preg_replace() 在 替换 字符 串 中 对 逆向 引用 作 正 常 的 替换 ， 将 
其 作为 PHP 代码 求 值 ， 并 用 其 结果 来 替换 所 搜索 的 字符 串 。 只 有 preg_replace() 使 用 
此 修正 符 ， 其 他 PCRE 函数 将 忽略 。 

@ A (PCRE ANCHORED ) : 如 果 设 定 了 此 修正 符 ， 模 式 被 强制 为 “anchored”， 即 强 
制 仅 从 目标 字符 囊 的 开头 开始 匹配 。 

@ D (PCRE DOLLAR_ENDONLY ) : 如 果 设 定 了 此 修正 符 ， 模式 中 的 行 结束 ($) 仅 匹配 
目标 字符 串 的 结尾 。 没 有 此 选项 时 ， 如 果 最 后 一 个 字符 是 换行 符 ， 也 会 被 匹配 。 如 果 
设 定 了 mm 修正 符 ， 则 忽略 此 选项 。 

@。 S: 当 一 个 模式 将 被 使 用 若干 次 时 ， 为 加 速 匹配 而 得 先 对 其 进行 分 析 。 如 果 设 定 了 此 修 
正 符 则 会 进行 额外 的 分 析 。 目 前 ， 分 析 一 个 模式 仅 对 没有 单一 国定 起 始 字符 的 non- 
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anchored 模式 有 用 。 

U (PCRE UNGREEDY ) : 使 “?” 的 默认 匹配 成 为 贪 禁 状态 的 。 

X (PCRE_EXTRA ) : 模式 中 的 任何 反 儿 线 后 面 跟 上 一 个 没有 特殊 意义 的 字母 导致 一 
个 错误 ， 从 而 保留 此 组 合 以 备 将 来 扩充 。 默 认 情 况 下 ， 一 个 反 锋线 后 面 跟 一 个 没有 特 
殊 意义 的 字母 被 当成 该 字母 本 身 。 

u (PCRE_UTF8 ) : 此 修正 符 启 用 了 一 个 PCRE 中 与 PERL 不 兼容 的 额外 功能 。 模 式 
字符 串 被 当成 UTF-8。 


10.2.4 字符 应 用 


本 节 将 综合 以 上 几 小 节 知 识 ， 通 过 对 一 些 正则 表达 式 的 构成 分 析 ， 来 进一步 理解 以 上 几 小 节 
学 习 到 的 知识 。 另 外 ， 举 一 些 实例 来 学 习 如 何 创建 一 个 正则 表达 式 。 下 面 先 分 析 几 个 比较 简单 的 
正则 表达 式 。 


ab*: 和 ab{0,} 同 义 ， 匹 配 以 a 开头 ， 后 面 可 以 接 0 个 或 者 n 个 b 组 成 的 字符 串 ， 如 
a、ab、abbb 等 。 

ab+: 和 ab{l,} 同 义 ， 但 最 少 要 有 1 个 b 存 在 ， 如 ab、abbb 等 。 

ab?: 和 ab{0,1} 同 义 ， 可 以 没有 或 者 只 有 1 个 b， 如 a、ab。 

a2b+$: 匹配 以 1 个 或 者 0 个 a 再 加 上 1 个 以 上 的 b 为 结尾 的 字符 串 ， 如 ab、abb 等 。 


以 上 几 个 正则 表达 式 示例 ， 只 是 匹配 单一 字符 ;如 果 想 匹配 多 个 字符 ， 可 以 使 用 0 将 需要 匹 
配 的 字符 括 住 。 下 面 是 几 个 正则 表达 式 示例 。 


a(bc)*: 匹配 a 后 面 跟 0 个 或 者 1 个 bc 的 字符 串 。 如 该 模式 可 以 匹配 a、abc、 
abcbc 等 。 


而 使 用 中 括号 括 住 的 内 容 只 能 匹配 一 个 字符 ， 如 下 面 的 正则 表达 式 所 示 。 


[ab]: 匹配 单个 的 a 或 者 b ， 该 模式 和 a | b 同 义 。 如 匹配 a、b。 
[a-d]: 匹配 a 到 d 的 单个 字符 ， 该 模式 和 a | b | c | d 及 [abcd] 同 义 。 


下 面 看 几 个 稍微 复杂 的 正则 表达 式 。 
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^[a-zA-Z_]$: 匹配 所 有 的 只 有 字母 和 下 划 线 的 字符 囊 。 这 里 之 所 以 在 模式 开头 加 上 人 ^ 在 
模式 结尾 加 上 $， 是 为 了 匹配 只 含有 字母 和 下 划 线 的 字符 囊 ， 因 为 ， 如 果 不 加 ^ 和 $， 那 
么 凡是 含有 字母 和 下 划 线 的 字符 囊 均 会 被 匹配 。 

人 ^[a-zA-Z0-9_]{1,}$: 匹配 所 有 包含 一 个 以 上 的 字母 、 数 字 或 下 划 线 的 字符 串 。 
^[0-9]{1,}$: 匹配 所 有 的 正 数 。 

A^{0,1}[0-9]{1.}$: 匹配 所 有 的 整数 。 含 负数 ， 在 负 号 前 加 了 转 义 符号 \。 

入 -{0,1}[0-9]{0,}\.{0,1}[0-9]{0,}$: 匹配 所 有 的 小 数 。 


【 第 10 章 正则 表达 式 





10.3 yirur 


本 节 实 现 利 用 PHP 正则 表达 式 验 证 URL 合法 性 的 示例 。 一 个 合法 的 URL 如 : 
http://www.php.net 或 www.php.net。 其 构造 规则 为 : [协议]://[www].[ 域 名 ].[comlnetlorg.…]。 

根据 上 一 节 学 过 的 个 各 种 符号 ， 可 以 构造 下 面 的 正则 表达 式 : 
http:MVMWV)?[a-zaR-50-9]+(\.[a-zR-Z0-9]f)* 


其 中 ，“^http:” 定 义 能 匹配 规则 的 字符 串 开头 是 “http:”; “W” 用 到 转 义 符号 \， 匹 配 了 
“//”。 完 成 验证 URL 合法 性 的 代码 如 下 所 示 。 


【示例 10-3】 验 证 URL。 





本 例 效果 如 图 10.1 所 示 。 


141 


国 Iocalhost/10-3.php = 

€ 3 CC Dlocalhost/10-3.php 

汪 应 用 肝 互 联网 职业 技能 - ，。 讽 资源 总 | 数组 卫 云 深 堂 -网易 云 课堂。 > 
字符 串 ' http://www. baidu. com' : 是 合法 的 RI 格式 








字符 串 ' www. sohu. com' ， 是 合法 的 URL 格 式 

字符 串 ' http://www. baidu. com/map/index. html” ， 是 合法 的 URL 格 式 
字符 串 ' //bai du. com' ， 是 不 合法 的 URL 格 式 

字符 串 ' :www. sohu. com :是 不 合法 的 URL 格 式 





图 10.1 验证 URL 效果 


1 0. 人 4 验 ij 电话 号 码 


本 小 节 实现 利用 PHP 正则 表达 式 验 证 北京 市 电话 号 码 合法 性 的 示例 。 合 法 的 号 码 如 : +86 
010X XXXXXXX， 其 构造 规则 为 : [+86] [010][ 八 位 数字 ] 

根据 上 一 小 节 的 构造 正则 表达 式 ， 可 以 构造 下 面 的 规则 : 
eeN+r86[[:space:]]010[0-9]18}15S 

其 中 ，“A^\+86” 定 义 能 匹配 规则 的 字符 串 开 头 是 “+86”; “[[:space:] ”表示 随后 一 个 空 
格 ; 而 “[0-9]{8}$” 表 明 以 8 个 数字 结尾 。 

完成 验证 北京 市 电话 号 码 合法 性 的 函数 如 下 所 示 。 


【示例 10-4】 验 证 电话 号 码 。 
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在 Web 应 用 技术 中 ， 数 据 库 的 操作 是 必 不 可 少 的 ， 包 括 对 数据 库 表 的 增加 、 删 除 、 修 改 、 
查询 等 功能 。 现 如 今 ， 数 据 库 可 以 分 为 关系 型 数据 库 和 非 关 系 型 数据 库 ， 关 系 型 数据 库 主要 有 
MySQL、Oracle、DB2、Infomix、SQL Server 等 ; 而 非 关 系 型 数据 库 主 要 有 NoSQL、voltDB 等 
数据 库 。 在 本 章 ， 主 要 介绍 MySQL 数据 库 的 基本 概念 与 基本 知识 。 











及 元 | 本 书 如 无 特别 说 明 ， 其 数据 库 的 操作 都 是 在 MySQL 数据 库 环境 下 进行 。 | 











什么 是 MySQL 


MySQL 数据 库 是 一 款 小 型 的 关系 型 数据 库 ， 它 以 
其 自身 的 特点 (例如 : 体积 小 、 速 度 快 、 成 本 低 等 ) 独 client 
树 一 帜 。 因 其 有 如 上 特性 使 得 MySQL 数据 库 是 目前 最 
受 欢迎 的 开源 数据 库 之 一 

本 节 介绍 MySQL 的 基本 概念 。 一 坊间 一 


client server 
| 一 返回 数据 一 一 | 








访问 


| 一 返回 数 据 一 























11.1.1 客户 端 /服务 器 软件 


客户 端 -服务 器 架构 被 称 为 C/S 架构 ， 是 一 种 网 络 client 返回 数据 一 
架构 ， 也 是 一 种 设计 架构 。 在 该 架构 下 软件 被 称 为 客户 访问 
端 软 〈Client) 件 和 服务 器 〈Server) 软件 。 它 们 之 间 图 11.1 客户 端 与 服务 端的 关系 
的 关系 如 图 11.1 所 示 。 

可 以 理解 为 服务 器 是 应 用 系统 的 核心 ， 客 户 端 则 处 理 自身 相应 的 功能 ， 共 同 实现 完整 的 应 
用 。 在 客户 端 /服务 器 中 ， 客 户 端 用 户 的 请 求 数 据 传送 到 数据 库 服 务 器 ， 数 据 库 服务 器 进行 数据 
过 滤 处 理 后 ， 将 结果 返回 给 客户 。 用 户 使 用 应 用 程序 时 ， 首 先 启动 客户 端 通过 命令 告知 服务 嚣 进 
行 操作 。 每 一 个 客户 端 软件 的 实例 都 可 以 向 另外 一 个 服务 器 或 应 用 程序 服务 器 发 出 请 求 。 

此 系统 的 特点 就 是 ， 客 户 端 跟 服务 器 程序 相对 独立 ， 不 在 同一 台 机 器 上 运行 。 


























11.1.2 ”MySQL 版 本 
MySQL 被 Oracle 收购 后 ， 针 对 不 同 的 用 户 有 不 同 的 版 本 ， 分 别 如 下 : 
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@ MySQL Community Server: 社区 版 完全 免费 ， 但 是 官方 不 提供 技术 支持 。 

@。 MySQL Enterprise Server: 企业 版 能 够 为 企业 提供 高 性 能 的 数据 库 应 用 ， 以 及 高 稳定 性 
的 数据 库 系 统 ， 提 供 完整 的 数据 库 提 交 、 回 滚 以 及 锁 机 制 等 功能 。 但 是 该 版 本 收费 ， 
官方 只 提供 电话 支持 。 








各 MySQL Chuster 主要 用 于 建立 数据 库 集 群 服务 器 ， 澳 要 在 以 上 两 个 版 本 的 基础 上 使 用 。 | 











MySQL 的 命名 机 制 由 3 个 数字 组 成 ， 例 如 : MySQL-5.6.15。 


(1) 第 一 个 数字 5 是 主 版 本 号 ， 用 于 描述 文件 格式 ， 表 示 所 有 版 本 5 的 发 行 版 都 有 相同 的 
文件 格式 。 

(2) 第 2 个 数字 6 是 发 行 级 别 ， 它 与 主 版 本 号 组 合 在 一 起 就 构成 了 发 行 序列 号 。 

(3) 第 3 个 数字 15 是 此 发 行 系列 的 版 本 号 。 目 前 MySQL 5.7.15 版 本 是 最 新 版 本 。 








一 旧版 本 的 MySQL， 例如 MySQL4.1、4.0 以 及 3.13 版 本 ， 官 方 将 不 再 提供 技术 支持 。 而 所 有 
发 布 的 MySQL 版 本 都 有 经 过 严格 的 测试 ， 可 以 保证 其 正常 使 用 。 针 对 不 同 的 系统 ， 读 者 应 
| 该 从 MySQL 官方 网 址 (httpy/devMySQL.com/downloads/) 下 载 相应 的 安装 文件 。 











11.1.3 ”MySQL 的 优势 

MySQL 的 主要 优势 如 下 : 

(1) 速度 运行 速度 很 快 。 

(2) 费用 : 对 于 个 人 版 免费 。 

(3) 易 用 性 : 与 其 他 关系 型 数据 库 相 比 ， 管 理 与 使 用 相对 简单 且 易 于 学 习 。 

(4) 可 移植 性 ， 可 运行 在 多 个 系统 平台 上 ， 例 如 主流 的 Windows、Linux、UNIX 等 。 

(5) 丰富 的 API 接口 : 提供 了 用 于 JAVA、PHP、Python、Ruby、C、C++ 等 语言 的 API。 

(6) 提供 查询 语言 ，MySQL 数据 库 利 用 标准 SQL 语法 查询 数据 。 

(7) 安全 性 : 灵活 和 安全 的 权限 密码 系统 ， 允 许 主机 的 验证 。 连 接 服 务 器 时 ， 密 码 传 输 均 
采用 加 密 方式 。 


1 .2 安装 与 配置 MySQL 5.6 


MySQL 支持 不 同 的 操作 系统 平台 ， 虽 然 在 不 同 平台 下 的 安装 和 配置 都 不 相同 ， 但 是 差别 也 
不 是 很 大 。 在 Windows 平台 下 可 以 使 用 二 进 制 的 安装 包 或 者 免 安装 版 的 软件 包 进 行 安装 ， 安 装 
包 提 供 图 形 化 的 安装 向 导 过 程 ， 免 安装 版 则 直接 解压 就 能 用 。Linux 平台 下 使 用 命令 安装 
MySQL， 但 由 于 Linux 有 很 多 的 版 本 ， 因 此 不 同 的 Linux 平台 需要 下 载 相 应 的 MySQL 安装 包 。 
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本 小 节 主要 叙述 Windows 平台 下 的 MySQL 的 安装 和 配置 过 程 。 


Windows 平台 下 提供 两 种 安装 方式 : MySQL 二 进 制 版 和 免 安 装 版 。 一 般 来 说 ， 应 该 采用 


该 采用 一 
进 制版 ， 因 为 该 版 本 在 使 用 起 来 比较 简单 ， 不 用 第 三 方 工具 来 启动 就 可 以 运行 MySQL。 这 里 采 
用 二 进 制 的 安装 方式 。 





1. 下 载 MySQL 安装 文件 
有 具体 的 下 载 操作 步骤 如 下 : 


(1) 打开 常用 浏览 器 ， 输 入 网 址 :http:/devmysql.com/downloadsmysql， 页 面 自动 跳 转 到 
MySQL Community Server 5.6.15 下 载 页 面 ， 选 择 Generally Available(GA) Release 选项 卡 ， 下 载 
界面 如 图 11.2 所 示 。 


Senerally Available (GA) Releases 。 Development Releases 


MysQL community server 5.6.15 
Select platforml 


Microsoft windows 


Recommended powntoad: 


Mys ane 5.6 
La for Windows 


All MySQL Products. For All Windows Platforms. | > 
In One Package- 


Windows (x86, 64-blt), MySQL Installer MSI 


Other Downloads: 


windows (xae, 32-blt), Zi 
Archive 





SWwn32.up) 





(x86, 64 Ei zp 











11.2 MySQL 下 载 界面 
(2) 在 下 拉 列 表 框 中 选择 Microsoft Windows 平台 ， 如 图 11.3 所 示 。 


My Available (GA) Releases Development Releases 


MySQL Community Server 5.6.15 


A 选择 操作 系统 








nded Download: 


MySQL Installer 5.6 
ES for Windows 


于 
| 


In One Packag: 






Windows (x86, 64-bit), MYSQL Installer ms 











{C86, 64-bit), Zp 


5.6.15 


zczm oe | 








图 11.3 选择 Microsoft Windows 平台 
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(3) 可 以 选择 网 络 安装 二 进 制 或 者 直接 下 载 二 进 制 文件 ， 在 这 里 选择 直接 下 载 二 进 制 文 
件 ， 单 击 Download 按钮 下 载 ， 如 图 11.4 所 示 。 





Generally Available (GA) Releases Development Releases 


MySQL Installer 5.6.15 


Select Platform: 





Microsoft Windows > 


Windows (x86, 32-bit), MSI Installer 


MD5: 2b109eb606619e9408cc597409ba4b06 | Signature 


5.6.15 234.8M 


MD5: 375458d0e5d5343f6d6220d90cfcbsla | Signature 


(mysql-installer-web-community-5.6.15.0.msi) 
Windows (x86, 32-bit), MSI Installer 


(mysql-installer-community-5.6.15.0.msi) 








图 11.4 单 击 下 载 MySQL 二 进 制 文件 


2. 安装 和 配置 MySQL 数据 库 


MySQL 二 进 制 文件 下 载 完 成 后 ， 找 到 下 载 文件 〈 例 如 d\ MySQL-installer-5.6.15.msi)》， 双 
击 进行 安装 ， 具 体 步 骤 如 下 。 


(1) 双击 下 载 的 MySQL-installer-community-5.6.15.0.msi 文件 ， 如 图 11.5 所 示 。 





| 更 mysql-installer-communitgy-5.6.15.0.msi Windows instal- 240,420 KB installer 





11.5 MySQL 安装 文件 
(2) 等 待 Windows 系统 检测 MySQL 安装 环境 ， 如 图 11.6 所 示 。 


MySQL Installer 





本 汪汪 


Time remaining: 10 seconds 











9 [cuesaa 








图 11.6 ”Windows 系统 检测 MySQL 安装 环境 
(3) 弹出 安装 MySQL 选择 对 话 框 ， 选 择 “Install MySQL Products”， 如 图 11.7 所 示 。 
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EE wsot Installer Ee 








Welcome MysQL 


The MySQL Instaler guides you through the instalation and coniiguration of your | 
MySQL Products Run tt from the Start Menu to perform mantenance tasks later. 


Select one of the actions badow 


Tstal MvsO product 
EH purosg te rekon and enforason of yor 


和 About MySQL 
六 上 keammore aboutmsQt poduch end betier understondhow 
you an benefk the most 


Resources 
ee rorp formason on hew toretal Wet rd confiore tt 
run efficient on your 











图 11.7 选择 MySQL 产品 


(4) 弹出 安装 协议 对 话 框 ， 勾 选 同 意 协议 ， 单 击 Next 按钮 ， 如 图 11.8 所 示 。 


回 MysQL mstaler [一 > 一 








i 
s License Agreement 
MySQL. Installer 
To install HYSQL You must accept the Orade Software License Terms. 


me pe em 可 
Verson 2 ne i991 国 





(opment GE) es, poh ree orare Foneabn ie 





[rhe kenaca for most aofowere ore dcagned to ‘ohe amoy your frecdom 
shore ond chorge it. Cy contaat tre GHU Gereral Pubhc Licenoe 
Mended to Ou oiee yas freedon oshaeand derge fiee 
[iorvere--to make are he sofware s res for alts users, Th 
[enesal pubic Lcense appkes io mest of he Free sofmare 

fFoundaton's software and bb anr cther rogran whose athors conmt io 
lisnait. (Sone ohe Fres Software Founcaton sofinare is covered by 
|he GW Lorary Ganera Publc Lcense rstead.) You can apoly itto 








re proyr ome, 3rd Wat yo Ow Yo Eon do hese tngs, 


园 Laccept the bcense terms 


Es Bs =n 








图 11.8 ”MySQL 协议 对 话 框 


(5) 查找 最 新 产品 ， 可 以 选择 跳 过 此 步骤 ， 单 击 Execute 按钮 ， 继 续 执行 ， 如 图 11.9 所 
示 。 
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回 wysQt mstaler 












RN Find latest produdts 
MySQL. Installer 


Before the installation 5 performed, the Installer wal check if there are newer 
Versions of the products you are about to Instal | already installed are avallable. 


DO Comectto te lrtenet 


DO Feth procuct pdate nbrnaton 


| se te heck for uptates (rotrecemmenced) 


Ce [eee | Loe) 











图 11.9 查找 最 新 MySQL 产品 


(6) 选择 安装 类 别 ， 有 5 中 类 别 可 以 选择 ， 分 别 是 开发 版 (Developer Default) 、 服 务 器 版 


(Server Only) 、 客 户 端 〈Client Only) 、 全 部 MySQL (Full) 、 经 典 版 Custom) 。 在 此 ， 本 
书 选择 开发 版 并 选择 指定 的 安装 目录 ， 如 图 11.10 所 示 。 


[ws maaer 





(= | 





i Choosing a Setup Ty 
MySsQL Installer Led 


Please select the Setup Type that suits your use case. 





® peveper Defaut 地 
cee or 





Iinotale al ruded MSQL procuets Pa 


图 ' 




















11.10 选择 安装 类 别 








性 寺 MySQL 默认 安装 路 径 “CsProgram Files\MySQL”， 可 以 单 击 右 侧 的 … 按 钮 更 改 安装 路 径 ， 
[ 同样 MySQL 数据 路 径 也 可 以 单 击 右 侧 的 .… 按 钮 更 改 。 














(7) 检查 安装 的 必需 产品 ， 如 果 系统 中 没有 安装 相应 的 必需 工具 ， 可 以 返回 上 一 步 选 择 普 
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通 版 的 MySQL 类 别 或 者 直接 单 击 Execute 按钮 ，MySQL 会 过 滤 掉 相应 的 安装 程序 ， 等 系统 有 
了 对 应 的 软件 ， 可 以 重新 运行 安装 程序 进行 更 新 ， 如 图 11.11 所 示 。 


回 wysQt Installer 














RN Check ii ts 
MysQL Installer aa 


The folowng requirements must be nstaled before the seiected products can 
TREE cee the 
product that requirest. 





Reourenent For product Sbhs 
so pce 2907 or grearer MySQL Forpee 113 

eros ort NET Framewcrk 4 Chert srofie MySQL Natfier 11.4 

D Micogof visual c++ 2819 32-0t ranome MySQL Workbench CE S.0.5 

D wicosoft NET Framewerk 4 Chent prafile MySQL Workbench CES.0.8 






Check Requirements 











Visval Sudio 2008, 2010, 2012 MySQL for visual Sudio 1.0.2 

CumentTas 

Tre roduct WSO fer Youa Sd 1 0 reares esa Seche 2008, 2010, 201 butitwas 
ot detected on th macmine. “Vsual Shudio 2006, 2010, 7)12°reaires anvaj nstalaton and 


mt be nctaled prior io Inetaling SQL for Viea Shio 1.0.2° Fy ddang Evecute,, HySOL 
Wve She £07 wl be enoved fom te Wt of prodcts to ratal, Goes Nieusl 
Saric 2003, 2010, 2012 hos been met please run the MYSQL Irstaler oggin ond you wl bc 
ae to conplete nsialator. 











图 11.11 检查 必需 软件 
(8) 单 击 Execute 按钮 ，MySQL 开始 安装 或 者 更 新 ， 如 图 11.12 所 示 。 


回 wsaQt mealer 





Installation progress 


vs 
MySQL. Installer 


The following products will be installed or updated, 
a i 
wens aa 

Wor Wetesch ceeia Tobe valed 











Tebe netaled 








Tebe nstalled 








SQLUnloes 13.s Tobe nstaled 
Connedor/0DBC $2.6 Tobe nstaled 














nrectorct+ 113 Tebe netaled 








nnedtor S127 Tebe nstaled 
nnectorjNET $.74 Tobe nstaled 
MySQL ComectsriCE1 E12 Tebe nstaled 











MySQL Documestation 6115 Tebe netaled 














| sanples and amples 615 Tebe nstaled 
Chick [Evease] to nsial or uodste be folowng paciages 


a Ee 下 E 














图 11.12 MySQL 安装 界面 
显示 MySQL 安装 进度 ， 如 图 11.13 所 示 。 
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回 wsqr Installer 





Installation Progress 


RW 
MySQL. Installer 


Thefolowing products wil be instated or updated. 





Pmaud Saaz 





EE] wsar senerseis nstalling 





|] WsQr workbescn cesos To beinstaled 





司 macwonsaas obe nstated 





we roe :as Tobeinstaled 





区 ] WsoL vinees 135 Teseinetaled 
Conneaorjopec52.6 To perstaled 








Connedor/cH+ 113 Tbeinstaled 
Connederh s127 Tobeinetaled 





Conneor/NETS7.4 
国 Wset comecorcsistz 
EE wsat oamertaton sts 





国 comeewesan Tobeisioled 


Show peta > 











图 11.13 ”MySQL 安装 进度 


(9) 初始 化 配置 MySQL， 在 第 8 步 都 安装 完成 后 ， 单 击 Next 按钮 ， 跳 转 到 配置 页 面 ， 单 
击 Next 按钮 ， 如 图 11.14 所 示 。 


[MySQL Installer 





人 Configuration Overview 
MySQL. Installer 


The folowing products wil now be configured 


aa ctor tobe pertamec 
页 加 waa snessis Iinitil cenfguraton 











11.14 MySQL 配置 界面 
单 击 Next 按钮 ， 进 行 MySQL 端口 配置 ， 如 图 11.15 所 示 。 
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EO MySQL nstaller ET 
AN Mm 
> ysQL server Configuration 113 
MySQL. Installer 
Sorver Confguratine Type 


起 





CorfigType DaevacpmentMaoine - 


Enable TCP/IP Networking 








EE 

















图 11.15 MySQL 数据 库 端口 配置 
单 击 Next 按钮 ， 进 入 MySQL 管理 员 的 密码 设置 和 用 户 设置 ， 如 图 11.16 所 示 。 

















回 MysQL msaler [= 
RN 
As MySQL Server Configuration 213 
MySQL. Installer 
Koot Account password 
a Ente the password for the roo! a-count. Pease remember to store 
the passvord neare lace 
MySQt Root password: | 2 
Repeat Passwort: 
Peerae mmm ergti 4 
Corfigurabon 
ET 














11.16 MySQL 用户 和 密码 设置 
设置 完 ， 单 击 Next 按钮 ， 进 行 MySQL 服务 器 名 的 设置 ， 如 图 11.17 所 示 。 
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RN 
MysSQL. Installer 














图 11.17 MySQL 服务 器 名 的 设置 
配置 完 的 界面 如 图 11.18 所 示 。 


MySQL Installer 





Ne Configuration Overview 
MySQL. Installer 


The folowing products wal now be configured 


Produet Actont be pmrfomed 





Samples and Exarples 56315 mbal Configuretion 











图 11.18 MySQL 配置 完 初始 化 
单 击 Next 按钮， 进行 MySQL 示例 配置 ， 如 图 11.19 所 示 。 
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回 wsqr Instaler Em 
3 Configuration Overview 
MySQL. Installer 
The following products will now be configured. 
ea seton we peromed peeee 








机 
| 
i 
Ea 
| 


yaql acrver 5.5 wrxé :100 Procuct corfigrabon cont oler finahed confguragen 
ee 
exemples-5.€: 100 -Productconfguaon controlec frished configuiaton 











Re 





图 11.19 MySQL 示例 配置 
(10) 单 击 Next 按钮 ， 显 示 完成 ， 如 图 11.20 所 示 。 


| WseQt naaler 








A Installation Complete 
MySQL. Installer 


The instalation procedure has bean completed 


国 Start WysQ Workberch after Setup 














图 11.20 MySQL 安装 完成 界面 
单 击 Finish 按钮 ， 系 统 出 现 MySQL Workbench 图 形 化 界面 ， 如 图 11.21 所 示 。 
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图 11.21 MySQL Workbench 操作 界面 





启动 服务 并 登录 MySQL 数据 库 


安装 完 MySQL 数据 库 之 后 ， 需 要 启动 服务 进程 ， 相 应 的 客户 端 就 可 以 连接 数据 库 ， 客 户 端 
可 以 通过 命令 行 或 者 图 形 界 面 工具 登录 数据 库 。 本 节 介绍 如 何 启动 MySQL 服务 和 登录 MySQL 


数据 库 。 


11.3.1 启动 MySQL 服务 


在 默认 的 配置 中 ， 已 经 将 MySQL 设置 为 Windows 服务 ， 当 系统 启动 或 停止 时 ，MySQL 服 
务 会 自动 启动 或 者 关闭 。 但 是 ， 用 户 还 可 以 通过 图 形 服务 工具 来 控制 MySQL 服务 器 或 者 从 命令 


行使 用 命令 启动 。 


可 以 通过 Windows 的 服务 进行 管理 ， 具 体 的 操作 步骤 如 下 。 


(1) 单 击 “ 开 始 ” 菜 单 ， 在 弹出 的 菜单 中 输入 “services.msc” 命 令 ， 打 开 Windows 的 “ 服 
务 管理 器 ”， 在 其 中 可 以 看 到 服务 名 为 “MySQL56” 的 服务 项 ， 右 边 状 态 为 “已 启动 ”， 表 明 


该 服务 已 经 启动 ， 如 图 11.22 所 示 。 





名 称 所 述 。 状态 。 启动 并 
MySQL56 已 启动 自动 
Net Msmq Listener Adapter 通过 .. 人 用 
Netpipe Listener Adapter 通过 … 大 用 
Net.Tcp Listener Adapter 通过 .… | 
NetTcp Port Sharing Service 。 ”提供 .. 全 用 
Nedogon 为 用 手动 
Network Access Protection Age-， 网 阁 - 手动 
Network Connections 管理 已 启动 手动 
Network List Service 识别 -。 已 启动 手动 
Network Location Awareness 收集 已 启动 ”自动 
Network Store Interface Service ”此 服 .。 已 主动 生动 





登录 为 

网 络 服务 
网 络 服 务 
本 地 服务 
本 地 服务 
本 地 服务 
本 地 系统 
网 阁 服务 
本 地 系统 
本 地 服务 
网 络 服 务 
本 地 服务 





图 11.22 服务 管理 器 窗口 
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(2) 从 图 11.22 中 可 以 看 出 MySQL 启动 类 型 为 自动 ， 且 该 服务 已 经 启动 。 如 果 状 态 为 空 
白 ， 说 明 服 务 未 启动 。 启 动 方法 为 : 双击 MySQL 服务 名 ， 打 开 “MySQL56 的 属性 ”对 话 框 ， 
在 其 中 通过 单 击 “ 启 动 ”或 者 “停止 ”按钮 来 改变 服务 状态 ， 具 体 如 图 11.23 所 示 。 



































MySQL56 的 尾 性 (本 地 计算 机 ) 

常规 

服务 名 称 : 

显示 名 称 : 

撕 述 : 

可 执行 文件 的 路 径 

“D: \Progr anFiles\MySQL\ySQL Server 5.6\bin\nysqld” -defau] 
启动 类 型 中): | 自动 - 


服务 状态 : 已 启动 
启 起 G) 售 止 9) | [暂停 中) 收 夏 O) 
当 从 此 处 启动 服务 时 ， 您 可 指定 所 适用 的 启动 参数 * 

















启动 关 孝 n) 




















ED ee) ft 





11.23 ” MySQL56 服务 属性 对 话 框 
也 可 以 通过 命令 行 启动 ， 启 动 方 法 如 下 。 


(1) 单 击 “ 开 始 ” 菜 单 ， 在 搜索 框 中 输入 “cmd”， 如 图 11.24 所 示 ， 按 回 车 键 弹出 
Windows 命令 操作 界面 。 


程序 (1) 
| 丽 cmd,exe 
文档 (9) 
国 1zip 
国 1zip 
国 1zip 
dsdbdfe7.findjs 
回 1e29e222.findjs 
0)] :ervlets.doc 
回 62481910.findjs 
回 6e860a2d.findjs 
国 functionsjs 
文件 (4) 
国 新 建 Microsoft Office Visio 绘图 vsd 
functionsjs 
国 | 任务 调度 接口 .docx 
国 groovy-binary-2.0.1zip 


用 可 者 更 多 结果 





[cma x] [Each 








1124 ”Windows 运行 界面 


(2) 输入 “net start MySQL56 ”， 按 回 车 键 ， 就 可 以 启动 MySQL56 服务 了 ,停止 
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MySQL56 服务 的 命令 为 “net stop MySQL56”， 如 图 11.25 所 示 。 





而 管理 员 : CNWindowsvsystem3zmd exe 三 [加 


:NUsers hdministrator 





图 11.25 命令 行 中 启动 和 停止 MySQL 





Ws 
本 元 | “net start MySQL56” 中 “MySQL56” 是 MySQL 服务 的 名 字 。 如 果 MySQL 服务 的 名 字 是 
| 其 他 名 字 ， 应 该 输入 “net start XX” 


11.3.2 ”登录 MySQL 数据 库 

当 MySQL 服务 启动 后 ， 可 以 通过 客户 端 来 登录 MySQL 数据库。 在 Windows 系统 中 ， 有 两 
种 方式 登录 MySQL 数据 库 。 

1. Windows 命令 行 登录 

具体 的 步骤 如 下 。 

单 击 “ 开 始 ” 菜 单 ， 在 弹出 的 对 话 框 中 输入 命令 “cmd”， 如 图 11.24 所 示 。 在 DOS 窗口 中 
通过 登录 命令 连接 到 MySQL 数据 库 ， 连 接 MySQL 的 命令 为 : 





MySQL -h hostname ~-u username -p 


其 中 MySQL 为 命令 ，-h 后 面 是 服务 器 主机 地 址 ，-u 后 面 是 登录 数据 库 的 用 户 名 ，-p 后 面 
是 用 户 登录 密码 。 在 这 里 由 于 MySQL 客户 端 和 服务 器 是 同一 台 机 器 ， 所 以 输入 命令 如 下 : 

















MySQL -h localhost -u root -p 


注 





« 回 车 键 ， 系 统 会 提示 输入 密码 “Enter password”， 如 图 11.26 所 示 ， 输 入 前 面 配 置 中 的 密 
码 ， 验 证 正确 后 ， 即 可 登录 到 MySQL 数据 库 ， 如 图 11.27 所 示 。 
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sql -h localhost -~u Foot -p 





图 11.26 输入 命令 提示 输入 密码 














图 11.27 Windows 命令 行 登录 窗口 





EE 、 
攻 却 当 窗 口中 出 现 图 11.27 所 示 的 描述 信息 ， 且 命令 提示 符 变 为 “MySQL>” 时 ， 表 明 已 成 功 登 | 
| 录 MySQL 服务 器 了 。 | 


2. 使 用 MySQL 命令 行 登 录 
依次 选择 “开始 ”|“ 所 有 程序 ”|MySQLIMySQL Server 5.6IMySQL 5.6 Command Line Client 
菜单 命令 ， 进 入 密码 输入 窗口 ， 如 图 11.28 所 示 。 


国 MySQL 5.6 Command Line Client | © 
ad: 


Enter passu 





图 11.28 MySQL 命令 行 登录 窗口 


输入 正确 的 密码 后 ， 就 可 以 登录 到 MySQL 数据 库 中 了 。 显 示 的 结果 跟 Windows 命令 行 登 
录 的 结果 是 一 样 的 。 


11.3.3 配置 Path 变量 


当 输 入 MySQL 登录 命令 可 以 登录 到 数据 库 时 ， 是 因为 把 MySQL 的 安装 目录 bin 目录 添加 
到 系统 的 环境 变量 中 ， 所 以 可 以 直接 使 用 。 手 动 配置 环境 变量 如 下 。 
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(1) 右 击 桌面 上 “我 的 电脑 ”图 标 ， 在 弹出 的 菜单 中 选择 “属性 ”菜单 命令 ， 如 图 11.29 
所 示 。 
(2) 打开 系统 属性 对 话 框 ， 选 择 “ 高 级 系统 设置 ”， 如 图 11.30 所 示 。 























[= | ls 
OO Ee, ee Wes， | 4 EeeaE 中 | 
Sd [二 


= 查看 有 关 计算 机 的 基本 信息 
储 TortoiseSVN | | 


映射 网 络 驱动 亏 (N)… 
新 开 网 络 驱 动 器 (O 〇 … 


创建 快 搜 方 式 (S) 
出 除 (D) 
重 命名 (M) 


属性 (R) 
图 11.29 “我 的 电脑 ”属性 菜单 图 11.30 系统 属性 对 话 框 


(3) 单 击 “ 环 境 变量 ”按钮 ， 如 图 11.31 所 示 ， 打 开 对 话 框 。 

(4) 在 系统 变量 列表 中 选择 “PATH” 变 量 ， 单 击 “ 编 辑 ” 按 钮 ， 在 “编辑 系统 变量 ”对 话 
框 中 ， 将 MySQL 应 用 程序 的 安装 目录 bin 目录 (C:\Program Files\MySQL\MySQL Server 
5.6\bin) 增加 到 变量 中 ， 用 分 号 与 其 他 路 径 分 开 ， 如 图 11.32 所 示 。 

有 弹性 Le 


[于 各 机 | 议 件 “| 高 如 |[ 素 统 保护 [去 程 | 
要 进行 大 多 娄 硬 光 、 人 必须 作为 ;图 吕 基 录 。 











wdow san 




































































性 能 
视 只 时 ， 处 于 尖 计 划 ， 庆 存 使 用 ， 忆 及 记忆 内 在 Er 二 
变量 值 V) m FilesWySQULWYSQL Sorver 5 6\bin 
用 户 中 置 文件 三 EE] 
与 间 录 再 关 扫 上 而 设置 
| [RE 
GD 1 | 
系统 岂 动 ， 系统 和 肪 向 计 信息 于 es | 
Path C:\Frogran Files tx86)\WD APP\. 
PATHEXT COW; .EXE; . BAT: . CI;. VBS; VBE; 
NC PNR Amia Sd 
(| 











图 11.31 单 击 “ 环 境 变量 ”按钮 图 11.32 “编辑 系统 变量 ”对 话 框 


(5) 添加 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 如 此 即 完 成 了 PATH 变量 的 配置 工作 ， 就 可 以 直接 
在 命令 窗口 中 输入 MySQL 命令 登录 数据 库 。 


1〗1 .4A 更改 MysQL 的 配置 


上 节 介绍 MySQL 数据 库 的 启动 服务 ， 使 读者 对 数据 库 的 启动 有 所 了 解 。 在 MySQL 数据 库 
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【 第 11 章 MySQL 的 安装 与 配置 


实际 使 用 过 程 中 ， 可 以 根据 系统 需要 来 更 改 MySQL 配置 参数 。MySQL 数据 库 更 改 配置 文件 的 
目录 一 般 在 MySQL 数据 库 安装 目录 下 。 

通过 更 改 配置 ， 可 以 加 深 对 数据 库 的 理解 ， 而 且 通 过 这 种 方式 也 是 更 快 更 好 地 学 习 数 据 库 的 
途径 ， 只 是 这 需要 对 每 个 参数 的 含义 必须 理解 。 

在 旧版 本 时 ， 安 装 目录 下 面 有 很 多 配置 文件 ， 例 如 my-hugeini、my-medium.ini 、my- 
smallini 这 3 个 配置 ， 它 们 分 别 对 应 的 是 大 型 系统 的 MySQL 配置 例子 、 中 型 系统 的 MySQL 配 
置 例子 、 小 系统 的 MySQL 配置 例子 。 现 在 只 有 一 个 配置 例子 my-default.ini。 

下 面 对 配 置 文件 在 的 参数 进行 简单 介绍 。 
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下 下 .5 MysQk 安装 失败 解决 方案 


虽然 MySQL 的 安装 和 配置 很 简单 ， 但 是 在 操作 过 程 中 ， 也 有 可 能 出 现 问题 ， 读 者 需要 多 实 
践 。 


1. 下 载 MySQL 失败 
下 载 过程 中 网 络 出 现 问 题 会 导致 失败 。 


2. MySQL 安装 失败 


安装 过 程 中 ， 大 多 是 安装 了 好 几 次 MySQL 数据 库 导致 ， 需 要 彻底 删除 相关 文件 。 解 决 办 法 
是 : 把 以 前 的 安装 目录 删除 ， 删 除 安装 文件 夹 ， 同 时 删除 MySQL 的 DATA 目录 ， 还 不 行 则 需要 
删除 注册 表 中 的 数据 ;然后 重新 安装 就 可 以 了 。 


3. MySQL 安装 服务 


一 般 来 说 ， 安 装 并 配置 完成 MySQL 数据 库 ， 系 统 会 默认 生成 一 个 MySQL 服务 到 系统 中 ， 
如 图 11.33 所 示 。 


Media Center Extender Service 
(Microsoft .NET Framework NG Mi 
| Microsoft .NET Framework NG Micr... 
BY Microsoft .NET Framework NG Mi 
Microsoft ,NET Framework NG Mi 
Microsoft Device Health Machi... 
(Microsoft Device Heahh Mana... 
Microsoft IME Dictionary Upd... 
Microsoft iSCSI Initiator Service 
入 Microsof Office Diagnostics S.. 
[Microsoft sharepoint Workspa.. 

PY Microsoft Software Shadow C... 
Mozilla Maintenance Service 
Multimedia Class Scheduler 


Net Msmaq Listener Adapter 
Net.Pipe Listener Adapter 


让- 
收集 


11.33 ”系统 服务 注册 图 
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第 12 章 
< 数据 库 的 基本 操作 > 


上 一 章 介绍 了 MySQL 数据 库 的 基本 知识 ， 如 何 下 载 安装 。 成 功 安装 并 启动 MySQL 服务 
后 ， 读 者 就 可 以 开始 学 习 这 个 简单 而 又 复杂 ， 强 大 而 又 轻便 的 数据 库 。 而 数据 库 的 基本 操作 包 
括 : 创建 数据 库 、 使 用 数据 库 和 删除 数据 库 。 本 章 将 逐一 介绍 这 些 内 容 ， 并 描述 不 同 的 数据 存储 
引擎 之 间 的 差异 性 。 


创建 数据 库 


学 习 基于 数据 库 的 开发 ， 掌 握 如 何 应 用 一 个 数据 库 并 熟练 使 用 数据 库 ， 是 学 习 的 目的 。 在 学 
习 如 何 创建 数据 库 之 前 ， 我 们 必须 了 解 MySQL 数据 库 中 默认 的 几 个 数据 库 ， 如 图 12.1 所 示 。 
= ee 








图 12.1 显示 默认 的 数据 库 界 面 





从 图 12.1 可 以 看 出 ， 有 6 个 数据 库 分 别 是 information_schema、mysql、performance_schema、 
test、world、sdkila， 它 们 之 间 的 作用 见 表 12.1 所 示 。 
表 12.1 默认 数据 库 说 明 





它 是 信息 数据 库 ， 库 中 保存 着 所 有 其 他 数据 库 的 信息 ， 提 供 数据 库 元 数据 的 访问 方 
式 。 例 如 ， 数 据 库 库 名 、 列 的 数据 类 型 ， 或 访问 权限 等 

mysql MySQL 核心 库 ， 用 于 存储 数据 库 的 用 户 、 权 限 设置 、 关 键 字 等 
performance_schema | 收集 数据 库 服务 器 性 能 参数 数据 库 ， 例 如 进程 等 待 的 详细 信息 、 历 史 寻 
test 用 户 的 测试 库 ， 用 来 测试 

示例 数据 库 ， 库 中 有 3 张 表 分 别 是 city、country、countrylanguage 
示例 数据 库 ， 库 中 有 很 多 示例 表 ， 读 者 可 以 进行 参考 





information schema 
















件 的 汇总 信息 等 



















































默认 数据 库 中 mysql 是 核心 库 ， 千 万 不 能 删除 ， 删 除 就 需要 重 装 数据 库 。 
系统 中 默认 的 数据 库 并 不 是 我 们 需要 保存 数据 的 数据 库 ， 如 果 我 们 要 新 建 数据 库 ， 语 法 如 下 : 


Create database [if not exists] XXX7 
或 者 
CREATE DATABASE [ IF NOT EXISTS ] XXX; 


如 上 所 述 ， 就 是 创建 数据 库 的 基本 语法 ， 可 以 看 出 它 的 规则 很 简单 的 。“create database” 
或 者 “CREATE DATABASE” 是 创建 标识 关键 字 ，“ 让 not exists” 或 者 “IF NOT EXISTS” 是 可 
选项 ， 表 示 如 果 不 存在 时 执行 创建 命令 ，“xxx” 是 要 创建 的 数据 库 名 称 。 


阳 元 | 在 MySQL 数据 库 中 ， 关 键 字 不 区 分 大 小 写 


【示例 12-1】 创 建 测试 数据 库 test。 





创建 测试 数据 库 ， 输 入 命令 如 下 。 
create database test; 


结果 如 图 12.2 所 示 。 


国 MysQL 5.6 Command Line Client 





图 12.2 创建 数据 库 


数据 库 创建 好 之 后 ， 可 以 使 用 命令 “show databases” 或 者 “SHOW DATABASES”， 查 看 
数据 库 中 是 否 有 新 增 test 数据 库 ， 如 图 12.3 所 示 。 








| 




















图 12.3 查看 现 有 数据 库 列表 
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从 图 12.3 中 可 以 看 出 ， 数 据 库 列表 中 存在 test 数据 库 ， 说 明 数 据 库 创 建成 功 。 


删除 数据 库 


顾名思义 ， 删 除数 据 库 就 是 将 现 有 的 数据 库 删除 ， 在 MySQL 中 删除 数据 库 与 所 有 的 关系 型 
数据 库 删 除数 据 库 - 样 ， 就 是 将 数据 从 一 个 物理 地 址 中 删除 ， 在 磁盘 空间 中 清除 掉 ， 因 为 数据 库 
就 是 一 个 存储 在 磁盘 上 的 文件 。 


drop database xxx; 

或 者 

DROP DATABASE XXX; 

如 上 所 述 ， 就 是 删除 数据 库 的 基本 语法 ， 可 以 看 出 它 的 规则 很 简单 。“drop database ”或 者 
“DROP DATABASE” 是 删除 标识 关键 字 ，“xxx” 是 要 删除 的 数据 库 名 称 。 如 果 数据 库 不 存 
在 ， 删 除 则 会 出 现 “ERROR 1008 (HY000): Can't drop database “xxx’;database doesn 't exit” 错 误 ， 
说 明 是 数据 库 不 存在 的 错误 。 下 面 以 删除 测试 数据 库 为 例 。 

【示例 12-2】 删 除 默认 测试 数据 库 test。 

在 删除 数据 库 前 ， 先 用 命令 “show databases” 查 看 现 有 的 数据 库 列表 是 否 有 test， 这 样 跟 删 
除 后 的 数据 库 列 表 进行 对 比 ， 输 入 命令 如 下 。 

Show databases; 


结果 如 图 12.4 所 示 。 
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图 12.4 ”删除 前 数据 库 列表 
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从 图 中 可 以 看 出 ， 库 中 存在 测试 数据 库 “test”， 然 后 执行 删除 数据 库 命令 : 
drop database test; 


执行 后 ， 再 用 “show databases” 命 令 查看 数据 库 列 表 ， 其 结果 如 图 12.5 所 示 。 





| 





国 MysQt 5.6 Comman 





n set (0.80 sec) 








图 12.5 ”MySQL 删除 数据 库 后 列表 








从 图 中 可 以 看 出 ， 数 据 库 列 表 中 已 经 不 存在 “test” 数 据 库 。 如 果 再 次 执行 删除 命令 时 ， 系 
统 会 提示 不 存在 数据 库 ， 删 除 出 错 ， 如 图 12.6 所 示 。 
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图 12.6 MySQL 执行 删除 数据 库 命令 错误 提示 


数据 库存 储 引 擎 


什么 是 数据 库存 储 引擎 ? 根据 不 同 的 数据 类 型 提供 不 同 的 存储 方式 ， 以 获取 最 好 的 方式 对 存 
储 的 数据 进行 增加 、 修 改 、 删 除 和 查询 操作 。 不 同 的 存储 引擎 提供 不 同 的 索引 方式 、 存 储 方法 、 
锁 表 方式 ， 不 同 的 存储 引擎 还 提供 特定 的 功能 对 数据 进行 处 理 ， 选 择 不 同 的 存储 引擎 ， 从 而 最 大 
限度 地 利用 其 强大 的 功能 。 关 系数 据 库 的 核心 就 是 存储 引擎 ， 同 样 MySQL 也 不 例外 。 
12.3.1 MySQL 支持 的 存储 引擎 

关系 数据 库 表 是 用 于 存储 关系 的 数据 结构 ， 某 些 表 简单 ， 某 些 表 复杂 ， 在 开发 过 程 中 ， 可 能 
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需要 各 种 各 样 的 表 。 在 MySQL 中 ， 没 必要 在 整个 数据 库 服务 器 中 使 用 一 种 存储 引擎 ， 可 以 针对 
具体 的 要 求 ， 对 每 张 表 使 用 不 同 的 存储 引擎 。 例 如 ， 要 求 事务 存储 用 InnoDB， 要 求 内 存 存储 用 
Memory， 要 求索 引 比 较 高 的 用 MyISAM。 可 以 使 用 show ENGINES 命令 查看 系统 所 支持 引擎 类 
型 ， 如 图 12.7 所 示 


SA 








丽 六 理 呈 CNWindows\eystem3N\emd.exe - mysql -hh 


ER TIE 


DEFRUL 


set 《8.98 sec) 











图 12.7 MySQL 数据 库 引 擎 


从 图 中 可 以 看 出 ee 刚直 该 引擎 是 否 可 以 使 用 ，DEFAULT 表示 系统 默认 引擎 ; 
Transaction 列 的 值 表示 该 引擎 是 否 支 持 事务 控制 。 下 面 介绍 常见 的 3 种 引擎 。 





1. MylSAM 存储 引擎 
@ MyISAM 存储 引擎 在 MySQL 5.5 版 本 之 前 是 默认 存储 引擎 ， 它 不 支持 事务 。 
下 面 来 看 个 例子 : 

【示例 12-3】 演 示 MyISAM 引擎 是 否 支 持 事务 。 

执行 步骤 如 下 : 

(1) 创建 表 user， 指 定 其 引擎 


疾 为 MyISAM。 
语句 如 下 : 
create table User 
Co int(10) ， 
name varchar (20) 


) engine=MyISAM; 


(2) 查看 创建 表 user 的 语句 ， 确 认 是 否 是 MyISAM 引擎 ， 其 结果 如 图 12.8 所 示 。 
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图 MySQL 5.5 Command Line Client = | 5 





CHARSFT=urf 8 











图 12.8 查看 user 表 引 擎 
从 图 中 可 以 得 知 ，user 表 的 引擎 为 MyISAM。 
(3) 为 表 user 添 加 2 条 数据 ， 语 句 如 下 。 
insert into user values(1,'lin'), (2,'zhou'); 
其 结果 如 图 12.9 所 示 。 


国 MySQL 5.6 command Line Client © EE 








图 12.9 查看 插入 列表 值 


(4) 开启 事务 : “start transaction;”。 
(5) 更 新 id 为 1 的 用 户 姓名 为 “wang”， 语 句 如 下 : 


update user set name='wang'where id=1; 


结果 如 图 12.10 所 示 。 





园 MySOL 5.6 Command Line Client = | ln 


affected 

















图 12.10 更 新 后 的 列表 
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(6) 对 更 新 后 的 数据 回 滚 ， 语 句 : “rollback”， 再 查询 列表 如 图 12.11 所 示 。 
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“0.80 sec》 


ted, 1 warning CQ 


t # from user 


in set 8.88 sec) 











图 12.11 回 滚 后 的 数据 列表 
从 图 12.11 可 以 看 出 ， 回 滚 后 的 数据 是 修改 之 后 的 数据 。 
@ 支持 BLOB 和 TEXT 数据 类 型 ， 且 可 以 被 索引 。 
增加 user 表 remark 字段 ， 其 类 型 为 TEXT， 语 名 如下: 
alter table user add remark text; 
查看 表 user 结构 如 图 12.12 所 示 。 
国 MysQL 5.6 Command Line Client eile) 
! Default ! Extra ! 


10> 
har<20> 


0.85 sec》 








图 12.12 增加 remark 字段 后 的 表 结构 


增加 user 表 的 字段 remark 全 文 索 引 ， 语 句 如 下 : 


alter table user add fulltext index (remark); 





查看 表 user 的 索引 情况 如 图 12.13 所 示 。 
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国 MysQL 5.6 Command Line Client el > | 


lter table user add fulltext indexCrenark); 
OK a 《8-B 


Non_unique: 1 
renark 








图 12.13 查看 表 user 全 文 索引 
从 图 12.13 中 可 以 看 出 ， 添 加 索引 时 全 文 索引 起 到 了 作用 (Query OK,2 rows affected)。 所 以 
MyISAM 是 支持 text 数据 类 型 的 全 文 索引 。 
@ ”使 用 MyISAM 引擎 创建 数据 库 ， 将 产生 3 个 文件 。 文 件 的 名 字 以 表 的 名 字 开 始 ， 扩 展 


名 则 指出 文件 类 型 。frm 为 结构 文件 ， 数 据 文件 的 扩展 名 为 .MYD， 索 引文 件 的 扩展 名 
是 MYI， 如 图 12.14 所 示 。 





el 


OE « Preoramoasts » MysQL » MysQL Server56 » data » org -| 万 





RR [a 





db.opt 
deptfrm 
deptibd 
emp,frm 
empibd 
productsfrm 
products 




















图 12.14 MyISAM 文件 类 型 
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2. InnoDB 存储 引擎 





现 如 今 MySQL 的 默认 引擎 就 是 InnoDB， 它 是 事务 型 数据 库 ， 具 有 支持 外 键 、 行 锁 、 非 锁 


定 读 等 特点 ， 具 体 特 性 如 下 : 


(1) InnoDB 具有 事务 安全 存储 性 能 ， 它 提供 给 MySQL 数据 库 回 





滚 、 提 交 和 崩溃 恢复 的 特 


性 。InnoDB 行 锁 在 SELECT 查询 的 时 候 锁 定 在 行 级 ， 那 么 查询 时 ， 就 可 以 与 MySQL 库 中 不 同 


表 的 类 型 联合 起 来 查询 。 


(2) InnoDB 引擎 查询 性 能 与 耗费 在 系统 资源 效率 方面 是 最 少 的。 因此 在 处 理 大 数据 时 以 优 


先 考 虑 该 引擎 。 


(3) InnoDB 的 表 跟 索引 在 一 个 逻辑 表 空 间 中 ， 表 空间 可 以 有 多 个 文件 。 





洲 


(4) InnoDB 支持 外 键 完整 性 约束 ， 这 与 Oracle 数据 库 的 特点 


- 样 。 


(5) 应 用 广泛 ，InnoDB 引擎 被 大 量 应 用 在 需要 高 性 能 的 大 型 数据 库 站 点 上 ， 例 如 : 淘宝 。 


InnoDB 存储 引擎 与 MyISAM 存储 引擎 的 显著 区 别 如 下 : 
@ 支持 事务 特性 。 
执行 步骤 如 下 : 
(1) 创建 表 user1， 指 定 其 引擎 为 nnoDB。 
语句 如 下 : 
create table userl 
L id int(10) ， 


name varchar (20) 
) engine=InnoDB; 


(2) 查看 创建 表 user 的 语句 ， 确 认 是 否 是 mnoDB 引擎 ， 其 结果 如 图 12.15 所 示 。 
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图 12.15 查看 userl 表 引 擎 
从 图 中 可 以 得 知 ，user 表 的 引擎 为 InnoDB。 
(3) 为 表 userl 添加 2 条 数据 ， 语 句 如 下 。 
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insert into userl values(1,'lin'), (2, 


甘 疆 


果 如 图 12.16 所 示 。 


'zhou'); 
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‘0.00 sec》 








”2hou’ ); 





图 12.16 


(4) 开启 事务 : 


“start transaction; ”。 


查看 插入 列表 值 





(5) 更 新 id 为 1 的 用 户 姓名 为 “wang”， 语 句 如 下 : 
Update Userl set name='wang' where id=1; 


其 结果 如 图 12.17 所 示 。 
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set (0.00 sec) 


rtt 
Ok, @ rows 


actions; 
affected 9.00 sec) 


where id=1; 
"field list’ 


wang 


nysql> update 


OK, 1 














图 12.17 更 新 后 的 列表 
(6) 对 更 新 后 的 数据 回 滚 ， 语 句 “rollback”， 再 查询 列表 如 图 12.18 所 示 。 
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Rows matched: 1 Changed: 1 Warnings: 8 


elect 











图 12.18” 回 滚 后 的 数据 列表 








从 图 12.11 可 以 看 出 ， 回 滚 后 的 数据 是 更 新 数据 之 前 的 数据 ， 也 就 是 回 滚 到 最 初 状 态 。 
@ 不 支持 BLOB 和 TEXT 数据 类 型 的 全 文 索引 

增加 userl 表 remark 字段 ， 其 类 型 为 TEXT， 语 句 如 下 : 

alter table Userl add remark text; 

查看 表 usel 结构 如 图 12.19 所 示 。 
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set 《8-BL sec) 











图 12.19 增加 remark 字段 后 的 表 结 构 


增加 userl 表 的 列 remark 全 文 索引 ， 语 句 如 下 : 
alter table userl add fulltext index (emark) 


查看 表 userl 的 索引 情况 如 图 12.20 所 示 。 
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图 12.20 查看 表 userl 全 文 索引 
从 图 12.20 可 以 看 出 ， 添 加 text 全 文 索引 时 ， 没 有 起 作用 “query ok，0 rows affected”。 所 
以 InnoDB 不 支持 text 的 全 文 索引 。 
12.3.2 ”各 存储 引擎 的 区 别 


存储 引擎 的 选择 关系 到 性 能 的 优化 ， 不 同 的 存储 引擎 有 各 自 的 特点 ， 所 以 要 对 各 自 的 情况 做 
出 正确 的 选择 。 各 引擎 的 特点 参见 表 12.2。 




















表 12.2 各 引擎 的 特点 
支持 事务 YES NO NO NO 
支持 全 文 索引 NO | yes | No | No 
支持 数据 索引 YES | YES | YEs | No 
支持 哈 希 索引 NO | No | YEs | No 
支持 数据 缓存 YES | No | NA | No 
支持 外 键 YES | No | No | No 








从 表 12.2 中 可 以 发 现 以 下 几 点 : 

对 事务 安全 性 要 求 较 高 的 表 ， 选 择 InnoDB 引擎 。 

对 查询 和 插入 效率 要 求 较 高 的 表 ， 选 择 MyISAM 引擎 。 

对 数据 量 小 的 ， 放 置 在 内 存 中 的 数据 的 表 ， 选 择 Memory 引擎 。 
对 于 归档 的 操作 频繁 的 表 ， 选 择 Archive 存储 引擎 。 


使 用 合适 的 存储 引擎 ， 对 于 提高 整个 数据 库 的 利用 率 和 性 能 以 及 应 用 的 整体 体验 都 是 十 分 关 
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键 的 。MySQL 数据 库 允 许多 个 表 用 多 种 引擎 并 存 的 现象 ， 所 以 读者 在 开发 时 ， 尽 量 用 合适 的 引 
擎 进行 开发 。 


查看 默认 存储 引擎 


前 一 节 介 绍 了 数据 库存 储 引 擎 以 及 之 间 的 差异 ， 实 际 上 存储 引擎 远 不 止 上 面 介绍 的 几 种 ， 那 
么 如 何 查 看 一 个 数据 库 的 默认 引擎 ? SQL 语句 “show engines” 可 以 帮助 读者 查看 系统 中 所 有 的 
存储 引擎 列表 ， 列 表 中 显示 出 默认 的 存储 引擎 ， 还 可 以 运用 “SHOW VARIABLES LIKE 
'storage_engine"” 或 者 “show variables like 'storage_engine"” 查 看 默认 引擎 ， 如 图 12.21 所 示 。 
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in set 8.88 sec) 











图 12.21 查看 默认 引擎 


图 中 显示 了 当前 数据 库 默 认 存 储 引擎 。 
众所周知 ， 不 同 版 本 MySQL 中 的 默认 存储 引擎 不 同 ， 例 如 MySQL 5.5 以 前 默认 是 
InnODB， 从 MySQL 5.6 之 后 默认 存储 引擎 就 是 MyISAM， 当 读者 想 要 用 最 合适 的 存储 引擎 去 存 
储 数 据 时 ， 可 以 修改 默认 引擎 ， 这 时 就 需要 修改 my-default.ini 配置 文件 ( 见 图 12.22) 即 可 ， 并 
重启 MySQL 数据 库 服 务 ，my-default.ini 文件 位 于 MySQL 安装 的 根 目录 下 。 




















图 1222 my-defaultini 配置 文件 


173 


实战 演练 一 一 创建 数据 库 的 全 过 程 


本 节 介绍 了 数据 库 的 两 个 基本 操作 : 数据 库 的 创建 和 删除 数据 库 。 对 于 这 2 个 基本 操作 ， 读 
者 是 必须 掌握 的 ， 因 为 它们 是 基础 的 基础 ， 想 要 掌握 更 多 的 知识 ， 这 2 种 操作 是 必须 会 的 。 因 
此 ， 本 节 通 过 例子 来 复习 创建 数据 库 。 

(1) 首先 ， 登 录 数 据 库 


登录 数据 库 有 2 种 方式 ， 用 命令 行 登陆 或 者 打开 MySQL 命令 行 。 
按 “win+R” 快 捷 键 打开 命令 行 ， 如 图 12.23 所 示 ， 输 入 数据 库 用 户 名 跟 密码 。 








国 | 管理 员 : C\Windows\system32\cmd.exe - mysql -hlocalhost -ur.. eal 


icrosoft Windows [ 卡 本 6.1.7688] 
版 权 所 有 <e> 2889 Microsoft Corporation。 人 


alhost -u rm 








图 12.23 命令 行 输入 





打开 MySQL 5.6 Command Line Client 对 话 框 ， 只 需 输 入 密码 登录 ， 如 图 12.24 所 示 。 
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2888. 281 














图 12.24 MySQL 5.6 Command Line Client 对 话 框 


(2) 创建 一 个 数据 库 ， 以 创建 bank 数据 库 为 例 ， 执 行 命令 “CREATE DATABASE if not 
exists BANK” 或 者 “create dataset if not exists bank”， 如 图 12.25 所 示 。 








国 MysQL 56 Command Line Client 
EATE DATABASE if not s BANK 


1 row affected (8.80 sec》 








图 12.25 创建 BANK 数据 库 
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提示 信息 “Query OK,1 row affected” 表 明 语 名 成功 执行 。 用 命令 “show databases” 查 看 现 
有 的 数据 库 列 表 如 图 12.26 所 示 。 
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图 12.26 查询 MySQL 数据 库 列 表 
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前 一 章节 介绍 了 数据 库 的 存储 引擎 以 及 数据 库 的 两 个 基本 操作 ， 相 信 读 者 对 于 数据 库 的 基本 
操作 已 经 十 分 熟练 ， 本 章 将 介绍 关于 MySQL 数据 库 中 男 外 一 重要 的 知识 点 一 一 数据 表 的 基本 操 
作 。 我 们 知道 ， 在 数据 库 中 数据 表示 基本 操作 单元 ， 是 数据 库 中 既 重 要 又 基本 的 操作 对 象 。 关 系 
型 数据 库 中 ， 数 据 表示 一 个 集合 ， 数 据 在 表 中 是 按照 行列 的 格式 来 存储 ， 类 似 于 Excel 中 的 行 
列 。 行 代表 记录 ， 列 代表 记录 中 的 域 。 

本 章 将 详细 介绍 数据 表 的 基本 操作 ， 包 括 : 创建 表 、 修 改 表 、 删 除 表 、 查 看 表 结 构 。 通 过 本 
章 的 介绍 可 以 掌握 数据 表 的 基本 概念 以 及 如 何在 MySQL 命令 行 或 者 MySQL 图 形 工具 下 对 数据 
表 进 行 操作 ， 理 解约 束 条 件 和 运用 其 规则 。 


1 本. 1 新建 数据 表 


新 建 数据 表 ， 即 在 已 有 的 数据 库 中 增加 表 ， 那 么 表 中 的 字段 ， 字 段 的 约束 条 件 ， 以 及 字段 直 
接 是 否 能 有 关联 ? 有 关联 的 情况 下， 关联 条 件 是 如 何 建立 的 ?本 节 将 为 读者 一 一 解答 这 些 疑问 。 


13.1.1 语法 形式 


在 创建 之 前 ， 需 了 解 创建 的 基本 语法 形式 ， 因 为 任何 一 个 数据 库 都 有 其 自身 独特 的 语法 形 
式 。MySQL 的 语法 基本 是 遵循 SQL92 标准 ， 所 以 其 创建 数据 表 的 语法 规则 如 下 : 





或 者 








column1 数 据 类 型 [conditioin]， 
column2 数 据 类 型 [conditioin]， 
column3 数 据 类 型 [conditioin]， 


如 上 所 述 ，“CREATE TABLE” 或 者 “create table” 是 创建 数据 表 的 关键 字 ，columl 或 者 
COLUMN1、colum2 或 者 COLUMN2、colum3 或 者 COLUMN3 是 需要 创建 的 字段 ， 数 据 类 型 包 
括 : int、varcahr、float、text、date、timestamp 等 诸多 类 型 ，conditioin 是 约束 条 件 ， 是 可 选项 ， 
它 包 括 not null、primary key、default value xxx 等 。 在 这 个 语法 中 ， 显 然 字 段 跟 类 型 是 必需 的 ， 
下 面 以 创建 学 生 表 来 具体 说 明 语 法 的 使 用 。 


【示例 13-1】 创建 学 生 表 student， 其 表 结构 如 表 13.1 所 示 。 其 中 主键 id 为 int 数据 类 型 ， 
字符 长 度 为 10byte; 学 生 姓名 name 为 varchar 数据 类 型 ， 字 符 长 度 为 20byte; 班级 编号 
classid， 字 符 长 度 为 10byte; 分 数 score 为 浮 点 型 float。 








表 13.1 student 表 结构 


int(10) 
varchar(20) 











创建 数据 表 的 步 又 如 下 : 
(1) 选择 创建 表 的 数据 库 ， 运 用 SQL 语句 “use test”， 如 图 13.1 所 示 。 





国 MysQL 5.6 Command Line Client [1 已 








图 13.1 选择 数据 库 
(2) 创建 student 表 ， 如 图 13.2 所 示 。 
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图 13.2 创建 student 表 
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上 述 语 句 执行 后 ， 库 test 中 便 创建 了 一 个 名 称 为 student 的 表 ， 使 用 SQL 语句 命令 “show 
tables” 查 看 现 有 的 表 ， 如 图 13.3 所 示 。 





国 MysQL 5.6 Command Line Client chs 








图 13.3 查询 表 





从 图 中 可 以 看 到 ，student 表 已 经 存在 test 库 中 ， 数 据 表 创建 成 功 。 


13.1.2 ”主键 约束 
上 一 小 节 介 绍 了 创建 表 的 基本 语法 ， 那 么 要 为 字段 添加 主键 约束 ， 该 如 何 添加 ? 何 为 主键 约 
束 ， 主键 约束 一 般 有 主键 列 必须 唯一 、 不 能 为 NULL 或 者 空 值 ， 所 以 一 般 定义 了 主键 就 说 明 该 
字段 是 唯一 的 且 不 为 null。 主 键 的 值 可 以 是 数据 库 随机 生成 的 序列 号 ， 也 可 以 是 指定 的 唯一 序列 
号 还 可 以 是 程序 中 生成 的 唯一 值 ， 例 如 可 以 用 时 间 日 期 转换 或 者 uuid 的 值 。 主 键 又 可 以 分 为 
联合 主键 和 单一 主键 ， 联 合 主键 是 多 个 字段 组 合 而 成 的 ， 而 单一 主键 即 一 个 字段 组 合 而 成 。 下 面 
将 分 别 介绍 这 2 种 主键 方式 。 
1. 单一 主键 
顾名思义 ， 单 一 主键 就 是 一 个 字段 组 成 ， 其 定义 方式 有 下 面 2 种 方式 。 
(1) 在 定义 列 时 指定 主键 ， 语 法 如 下 : 
column type primary key 
(2) 在 定义 列 完 后 指定 主键 ， 语 法 如 下 : 
primary key [column] 
它们 的 例子 说 明 分 别 如 下 : 


【示例 13-2】 定 义 数据 表 student ， 定 义 字段 id 为 其 主键 ， 且 是 在 字段 后 直接 说 明 ， 如 图 
13.4 所 示 。 
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昌 rows affected (B-B6 s 





图 13.4 定义 主键 


【示例 13-3】 定 义 数据 表 teacher ， 指 ) 
如 图 13.5 所 示 。 





段 id 为 主键 ， 且 是 在 所 有 列 都 定义 完 之 后 指定 ， 
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> create table teacher 


刘 
name 


» @ rows affected (@.86 sec》 





图 13.5 定义 主键 
2 种 定义 方式 ， 都 可 以 用 SQL 语句 “desc 表 名 ”来 查看 表 结 构 中 关于 主键 的 说 明 ， 以 此 查 
看 创建 主键 是 否 成 功 ， 例 如 查看 教师 teacher 表 结 构 ， 如 图 13.6 所 示 。 
国 MysQL 5.6 Command Line Client aS Xx | 


Query OK,. @ rows affected 《8-B6 sec) 


yp 


int 18> 
rch 
int C11> 


! addres varcharC5@> 1 9 





图 13.6 ”查看 表 结 构 
从 上 图 中 “Key” 列 可 以 看 出 标注 有 “PRI” (PRIMARY 缩写 ) ， 说 明 它 是 主键 列 。 进 
步 说 明 指 定 teacher 表 主 键 成 功 。 
2. 联合 主键 
单一 主键 是 一 个 字段 ， 联 合 主键 就 是 由 多 个 字段 联合 组 成 ， 通 常 定义 联合 主键 是 为 了 能 快速 
地 检索 数据 ， 一 个 字段 无 法 准确 确定 一 条 数据 时 才 使 用 ， 联 合 主键 的 指定 方式 也 有 如 下 2 种 : 























(1) 在 定义 列 时 指定 主键 ， 语 法 如 下 : 





179 


Column type primary key 





(2) 在 定义 列 完 后 指定 主键 ， 语 法 如 下 : 
Primary key [column]l,column2,...] 
这 里 只 介绍 后 一 种 定义 模式 的 例子 ， 例 子 如 下 : 


【示例 134】 定 义学 生 老 师 关系 表 stu_teacher， 为 了 确定 唯一 一 个 学 生 ， 可 以 把 学 生 
name、 老 师 id 联合 起 来 做 为 主键 ， 如 图 13.7 所 示 。 











蕊 丁丁 








图 13.7 创建 联合 主键 


从 图 中 可 以 看 出 ， 语 句 创建 了 由 name 和 teacher id 组 合 在 一 起 的 联合 主键 ， 如 此 就 可 以 通 
过 学 生 姓名 跟 老 师 确定 数据 ， 当 学 生 姓 名 跟 老 师 还 不 能 确定 唯一 性 时 ， 还 可 以 继续 添加 字段 为 其 
联合 主键 。 


13.1.3 “外 键 关 联 


所 谓 外 键 约束 是 表 与 表 之 间 的 关系 ， 通 过 某 一 列 进行 关联 ， 那 么 关联 的 字段 可 以 是 一 个 也 可 
以 是 多 个 ， 可 以 是 关联 表 的 主键 列 ， 也 可 以 是 普通 列 。 例 如 ， 班 级 表 t_class 的 主键 是 id， 在 学 
生 表 t_stu 中 有 一 个 class_id 与 班级 表 id 关联 对 应 ， 这 就 是 外 键 约束 。 在 删除 班级 表 中 某 一 班 
时 ， 那 是 不 允许 的 ， 数 据 库 会 报错 ， 因 为 其 被 t_stu 中 的 值 关联 了 ， 它 的 作用 在 于 保证 数据 参照 
完整 性 。 

通常 在 关联 关系 表 中 ， 称 关联 表 为 主 表 ， 外 键 所 在 的 表 为 从 表 。 





[constraint < 外 键 名 >] foreign key column 1, [column2 ....] 
References < 主 表 名 > columnl, [column2] 


如 上 描述 的 就 是 指定 外 键 的 约束 形式 ， 其 中 “外 键 名 ”就 是 指定 外 键 约束 的 名 称 ， 一 张 表 不 
能 有 两 个 相同 名 称 的 “外 键 名 ”， 也 是 建立 不 成 功 的 ，foreign key 后 的 列表 示 从 表 需 添加 外 键 约 
束 的 字段 列 ，“ 主 表 名 ” 即 被 从 表 引 用 表 的 名 称 ， 其 后 所 跟 的 列 是 主 表 中 定义 的 列 ， 也 是 外 键 中 
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关联 的 列 ， 从 表 中 的 列 与 主 表 中 的 列 必须 是 类 型 一 样 且 字符 限定 数 都 一 样 的 。 下 面 举 一 个 简单 的 
例子 来 说 明 如 何 指定 外 键 约束 。 


【示例 13-5】 修 改 例 13-1 中 创建 学 生 表 的 语句 ， 新 创建 一 学 生 班级 表 stu_class， 并 创建 外 
键 约束 。 其 中 class id 来 自 于 班级 表 t_class 表 的 主键 id。 

由 于 没有 班级 表 ， 那 么 先 创 建 一 张 班级 表 t_class 表 ， 其 表 结构 见 表 13.2 所 示 ， 创 建 表 语句 
如 图 13.8 所 示 。 























图 13.8 定义 表 t class 

表 13.2 t_class 表 结 构 
[a mm 元 编 
班级 名 和 


grade name varchar(20) 年 级 名 称 


字段 名 称 数据 类 型 备注 








然后 指定 class_id 列 作为 外 键 关 联 到 t_class 的 主键 id 上 ， 其 语句 如 图 13.9 所 示 。 创 建 之 后 
可 以 用 SQL 语句 “desc stu_class” 查 看 表 结 构 ， 其 结果 如 图 13.9 所 示 。 











图 13.9 ”创建 外 键 表 


从 图 中 可 以 看 出 ， 在 表 stu_class 中 添加 了 名 称 为 你 _stu_class 的 外 键 约束 ， 外 键 名 称 为 
class id， 依赖 于 表 t_class 的 主键 id， 这 样 创建 外 键 成 功 。 
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13.1.4” 非 空 约 束 
非 空 约束 实质 是 指定 表 中 的 某 字 段 不 能 为 空 。 其 指定 形式 比较 简单 : 
colum type not null 
或 者 
column type NOT NULL 


在 指定 了 列 的 非 空 条 件 ， 在 为 表 增加 数据 时 ， 指 定 非 空 的 数据 列 不 能 为 空 值 ， 否 则 数据 添加 
不 了 。 还 是 以 学 生 表 studen 为 例 ， 指 定 学 生 姓名 不 能 为 空 。 例 子 如 下 : 





【示例 13-6】 定 义学 生 表 student， 指 定 学 生 姓 名 不 能 为 空 ， 其 中 字段 有 主键 id，int 数据 类 
型 ， 学 生 姓 名 name，varchar (20) 数据 类 型 ， 班 级 编号 classid，int (10) 数据 类 型 ， 创 建 语句 
如 图 13.10 所 示 。 














图 13.10 建 表 student 


创建 之 后 用 SQL 语句 “desc student” 查 看 表 结构 ， 如 图 13.10 所 示 。 从 图 中 Null 列 ， 可 以 
看 出 name 字段 不 能 为 空 值 。 


13.1.5 ”唯一 性 约束 
唯一 性 约束 即 指定 某 字段 的 属性 为 唯一 的 ， 在 添加 数据 时 ， 不 能 有 相同 的 值 。 指 定 方式 有 2 种 : 
(1) 在 列 后 直接 指定 唯一 约束 限制 ， 语 句 如 下 : 
column type unique 
或 者 
column type UNIQUE 
(2) 在 定义 完 所 有 的 列 后 指定 唯一 约束 限制 ， 语 句 如 下 : 


unique (<column>) 


182 


或 者 

UNIQUE (<column>) 

第 一 种 跟 主键 约束 是 一 样 直 接 指定 关键 字 ， 第 二 种 在 所 有 列 都 定义 完 后 添加 关键 字 unique 
说 明 。 下 面 以 第 一 种 指定 方式 进行 介绍 。 

【示例 13-7】 定 义 班级 表 t_class1， 指 定 班 级 的 名 称 为 唯一 且 不 能 为 空 。 

创建 的 语句 如 下 : 


create table t classl 


( 

41d int(10) primary key, 

name varchar (20) unique not null ， 
grade name varchar (20) 

); 


创建 后 ， 可 以 用 SQL 语句 “desc t_class1 ”查看 表 结 构 。 其 结果 如 图 13.11 所 示 。 














图 13.11 定义 t_classl 的 名 称 唯一 且 不 为 空 


从 图 中 可 以 看 出 指定 列 name 为 唯一 且 不 为 空 。 





/© 
本 元 | 单 张 表 中 ，primary key 有 且 只 能 有 一 个 且 不 能 为 空 ， 但 是 unique 限制 可 以 是 多 个 。 





13.1.6 ”默认 值 

默认 值 是 为 表 中 的 列 指定 默认 值 ， 当 insert 语句 中 没有 给 字段 赋值 ， 那 么 系统 就 会 自动 为 这 
个 字段 赋值 上 设 定 的 默认 值 。 指 定形 式 比较 简单 ， 如 下 : 

column type default 默认 值 

默认 值 要 符合 定义 的 数据 类 型 ， 否 则 创建 表 时 会 报错 。 还 是 以 学 生 表 为 例 ， 定 义 默 认 班级 为 
“xx 班 ”， 例 子 如 下 : 
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【示例 13-8】 定 义学 生 表 student1， 指 定 学 生 的 班级 名 称 为 “1 班 ”。 
创建 的 语句 如 下 : 


create table studentl 

( 
id int(10) primary key ， 
name varchar (20) not null, 
classname varchar (20) default '1 班 '， 
score float 


); 


创建 后 ， 可 以 用 SQL 语句 “desc student1” 查 看 表 结构 。 其 结果 如 图 13.12 所 示 。 








Ee 





图 13.12 默认 约束 





图 中 在 “Default” 列 中 显示 “1 班 ”， 可 以 看 出 学 生 表 studentl 中 列 classname 拥有 了 一 个 
默认 值 “1 班 ”， 新 插入 的 数据 中 如 果 没有 指定 班级 ， 则 默认 都 是 “1 班 ” 的 学 生 。 


匈 是 


13.1.7 ”设置 自动 增加 属性 


自动 增加 属性 就 是 为 列 值 自动 生成 字段 值 ， 字 段 类 型 必须 是 
自动 增加 属性 ， 那 么 在 insert 数据 时 就 可 以 不 指定 寺 
成 。 

指定 自动 增加 的 形式 如 下 : 


整数 类 型 ， 当 为 某 个 字段 设 定 了 
股 列 和 字段 值 ， 让 MySQL 语句 自动 生 





column type auto increment 
或 者 
column type AUTO INCREMENT 


从 形式 上 看 ， 直 接 在 字段 后 添加 关键 字 “auto_increment” 或 者 “AUTO_INCREMENT” 就 
可 以 ，MySQL 的 默认 值 是 从 1 开始 的 。 下 面 我 们 继续 对 创建 学 生 表 studentl 进行 改进 。 
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【示例 13-9】 定 义学 生 表 student1， 指 定 学 生 的 编号 为 自动 增加 ， 班 级 默认 是 “1 班 ”。 


创建 的 语句 如 下 : 

create table studentl 
id int(10) primary key auto increment, 
name varchar (20) not null, 
classname varchar (20) default '1 班 '， 


score float 
); 


创建 后 ， 可 以 用 SQL 语句 “desc student1” 查 看 表 结 构 。 其 结果 如 图 13.13 所 示 。 


i 











图 13.13 ”新 建 表 studentl 自动 增加 主键 


从 图 中 列 extra 可 以 看 出 表 studentl 的 主键 id 属性 为 自 增 型 。 在 插入 记录 时 ， 默 认 的 id 值 从 
1 开始 ， 每 增加 一 条 记录 ， 该 值 自动 加 1 。 


查看 数据 表 结 构 


查看 数据 表 结 构 ， 在 前 面 的 章节 中 提 及 过 此 命令 ， 本 节 将 详细 介绍 。 查 看 数据 表 结 构 ， 一 般 
是 用 来 确定 创建 的 表 结构 是 否 正 确 ， 或 者 查看 表 中 的 字段 说 明 。 查 看 表 结 构 有 下 面 2 种 方式 : 

desc 表 名 

或 者 

DESC 表 名 

或 : 

show create 表 名 

或 者 

SHOW CREATE 表 名 
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第 一 种 方式 是 列 出 字段 、 字 段 类 型 以 及 约束 条 件 等 信息 ， 第 二 种 方式 是 列 出 创建 表 时 的 语 
名 。 下 面 分 别 介绍 这 2 种 方式 。 


13.2.1 查看 表 结 构 
desc 命令 可 以 查看 表 的 字段 信息 ， 前 面 介 绍 过 此 命令 : 
desc 表 名 
【示例 13-10】 使 用 desc 查看 表 t_class、 表 student、 表 teacher 的 表 结 构 。 


首先 ， 查 看 表 t_class 表 结 构 ， 如 图 13.14 所 示 。 








图 13.14 查看 表 t_class 


接着 ， 查 看 表 student 表 结 构 ， 如 图 13.15 所 示 。 








图 13.15 查看 表 student 


最 后 ， 查 看 teacher 表 结 构 ， 如 图 13.16 所 示 。 
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图 13.16 查看 teacher 


各 字段 代表 的 含义 见 表 13.3。 
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表 13.3 desc 命 令 后 的 结果 含义 


























type 数据 类 型 
null 表示 该 列 是 否 允 许 null 值 
key 表示 该 列 是 否 有 约束 条 件 ，pri 表示 该 列 是 主键 的 组 成 部 分 ，uni 表示 该 列 唯一 ， mul 
表示 该 列 设 定 的 值 允许 出 现 多 次 
default 表示 该 列 是 否 有 默认 值 
extra 表示 该 列 获取 的 附加 消息 ， 例 如 : auto increment 等 
综 上 所 述 ，desc 命令 可 以 查看 字段 名 、 字 段 类 型 、 是 否 为 空 值 、 是 否 为 主键 、 是 否 有 默认 
值 ， 以 及 额外 的 信息 ， 例 如 自动 增加 等 。， 


13.2.2 ”查看 创建 表 的 语句 


表 已 经 创建 完成 ， 但 是 想 查 看 创建 的 语句 是 否 正 确 ， 则 可 以 使 用 语句 “show create table” 查 


。 语 句 形式 如 下 : 


show create table 表 名 ; 

或 者 

SHOW CREATE TABLE 表 名 

此 语句 十 分 浅显 易 懂 ， 下 面 以 查看 班级 表 t_class 为 例 说 明 。 
【示例 13-11】 使 用 show create table 查看 表 t_class 创建 时 的 结构 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 窗口 。 
(2) 执行 语句 “show create table t_class”， 结 果 如 图 13.17 所 示 。 
WL 56 Commend Uine Ghent [| 








> DEFAULT NIL, 








图 13.17 查看 t_class 表 结 构 
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从 图 中 可 以 看 出 创建 表 的 语句 ， 存 储 引 擎 类 型 以 及 默认 字符 编码 等 信息 。 图 13.18 所 示 的 是 
图 13.17 的 清晰 版 ， 用 法 是 在 语句 后 加 “\G”， 字 母 “G” 必 须 大 写 。 
[Eel >| 





























图 13.18 ”加 参数 查看 t_class 表 结 构 


修改 数据 表 


上 两 节 介 绍 了 如 何 创建 表 和 如 何 查 询 表 结构 ， 使 得 大 家 对 创建 表 、 查 询 表 结 构 有 了 初步 印 
象 ， 从 语句 上 看 创建 语句 跟 约束 条 件 都 相对 比较 容易 理解 。 那 么 当 创建 完成 了 ， 发 现 创建 错误 ， 
例如 表 名 错误 、 字 段 类 型 错误 、 字 段 名 错误 、 少 字段 等 这 些 错误 ， 该 如 何 应 对 ? 本 节 将 逐一 对 这 
些 内 容 进行 介绍 。 





13.3.1 修改 表 名 
修改 表 名 ， 语 句 如 下 : 
ALTER TABLE < 旧 表 名 > RENAME [TO] < 新 表 名 >; 
或 者 
alter table < 旧 表 名 > rename [to] < 新 表 名 >; 


从 上 述 语 句 中 ， 可 以 看 出 “alter table...rename” 或 者 “ALTER TABLE...RENAME” 为 修改 
表 名 的 关键 字 ， 括 号 〈[]) 内 的 为 可 选 参数 。 下 面 例子 以 学 生 班级 stu_class 表 更 名 为 
student_class 表 为 例 说 明 其 用 法 。 





必 寺 | 在 MySQL 中， 关键 字 是 不 区 分 大 小 写 的 ， 但 是 为 了 跟 sql92 标准 统一 ， 一 般 都 是 大 写 。 | 








【示例 13-12】 将 学 生 班级 stu_class 表 更 名 为 student_class 表 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 。 
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(2) 用 语句 “show tables” 查 看 库 中 存在 的 表 ， 如 图 13.19 所 示 。 
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图 13.19 查看 库 中 表 
(3) 执行 修改 语句 如 下 : 


ALTER TABLE stu class RENAME student class; 


(4) 检查 表 stu_class 是 否 更 名 成 功 ， 使 用 “show tables” 查 看 数据 库 中 的 表 ， 如 图 13.20 所 示 。 





RE 
国 MySQL 5.6 Command Line client yx™"| 


ysql> show tab 


! Tables_in_tes 








图 13.20 ”执行 变更 表 后 的 结果 





从 图 13.20 可 以 得 知 表 student_class 已 经 存在 于 库 中 ， 而 表 stu_calss 查询 
功 。 
13.3.2 ”修改 字段 类 型 


当 字 段 类 型 错误 ， 要 修改 类 型 ，MySQL 数据 库 提供 如 下 方法 : 


alter table < 表 名 > modify < 字段 名 > < 数据 类 型 > 


不 到 ， 


表示 更 名 成 
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或 者 

ALTER TABLE < 表 名 > MODIFY < 字段 名 > < 数据 类 型 > 

从 上 述 语句 中 ， 可 以 看 出 “alter table...modify” 或 者 “ALTER TABLE...MODIFY” 为 修改 
字段 类 型 的 关键 字 ，“ 表 名 ”表示 需要 修改 字段 的 表 名 称 ，“ 字 段 名 ”表示 要 修改 的 字段 ，“ 数 
据 类 型 ”表示 要 修改 成 的 数据 类 型 。 下 面 以 修改 student_class 表 中 name 字段 的 数据 类 型 为 例 介 


绍 修改 字段 类 型。 





| 


修改 数据 类 型 时 ， 如 果 是 不 同 数据 类 型 之 间 的 修改 ， 需 要 清空 数据 才能 修改 成 功 。 例 如 ， 表 ] 
[ 中 的 原 有 类 型 为 varchar， 要 修改 成 nt， 那么 ， 需 要 清空 表 数 据 才 能 修改 成 功 。 





【示例 13-13】 将 学 生 班级 student_class 表 中 name 字段 的 数据 类 型 由 VARCHAR(20) 修 改 成 
VARCHAR(40)。 

执行 步骤 如 下 : 

(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 

(2) 使 用 语句 “usetest”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 

(3) 使 用 语句 “desc student class”， 查 看 修改 前 的 表 结 构 ， 结 果 如 图 13.21 所 示 。 
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! teacher 


lB pows in set CQ.80 s 


nysql> desc student_c 














图 13.21 查看 student_class 表 结 构 
从 图 中 可 以 看 出 name 字段 的 数据 类 型 为 varchar(20) 。 
(4) 执行 修改 语句 如 下 : 
ALTER TABLE student class MODIFY name VARCHAR(40); 


(5) 检查 字段 是 否 修改 成 功 ， 同 样 使 用 “desc student_class ”查看 表 student_class， 如 图 
13.22 所 示 。 
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图 13.22 查看 修改 类 型 


与 图 13.21 对 比 ， 可 以 发 现 表 student class 中 的 name 字段 数据 类 型 已 经 修改 成 
VARCHAR(40)， 表 明 字 段 数据 类 型 修改 成 功 。 


13.3.3 ”修改 字段 名 
当 字 段 名 错误 ， 要 修改 ，MySQL 数据 库 提供 如 下 方法 修改 字段 名 : 
alter table < 表 名 > change < 旧 字 段 名 > < 新 字段 名 > < 新 数据 类 型 > 
或 者 
ALTER TABLE < 表 名 > CHANGE < 旧 字 段 名 > < 新 字段 名 > < 新 数据 类 型 > 


从 上 述 语句 中 ， 可 以 看 出 “alter table...change” 或 者 “ALTER TABLE...CHANGE” 为 修改 
字段 名 的 关键 字 ，“ 表 名 ”表示 需要 修改 字段 名 的 表 名 称 ，“ 旧 字段 名 ”表示 要 修改 的 字段 ， 
“新 字段 名 ”表示 修改 后 的 字段 名 ，“ 新 数据 类 型 ”表示 要 修改 成 的 数据 类 型 ， 这 些 都 是 必 填 
项 ， 下 面 以 班级 student_class 表 中 score 字段 名 修改 为 sco 为 例 ， 介 绍 修改 字段 名 。 





【示例 13-14】 将 学 生 班 级 student_class 表 中 score 字段 名 修改 为 sco， 数 据 类 型 更 改 为 long 
(长 整 型 ) 。 


执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “usetest”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 使 用 语句 “desc student_class” 查 看 修改 前 的 表 结 构 ， 结 果 如 图 13.23 所 示 。 
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图 13.23 查看 student_class 表 结 构 
从 图 中 可 以 看 出 score 字段 名 称 为 score， 类 型 为 float。 
(4) 执行 修改 语句 如 下 : 
alter table student class change score sco int(5); 


(5) 检查 字段 是 否 修改 成 功 ， 同 样 使 用 “desc student_class” 查 看 表 student_class， 结 果 如 图 
13.24 所 示 。 


ULL 
1 NULL 








图 13.24 ”修改 表 名 后 的 表 结构 


与 图 13.23 对 比 ， 发 现 表 student_class 中 的 score 字段 ， 字 段 名 称 变 为 sco， 数 据 关 
int(5)， 表 明 字段 名 修改 成 功 。 





为 





本 元 | 如 果 不 想 修改 字段 类 型 ， 则 可 以 设置 数据 类 型 与 修改 前 一 样 的 数据 类 型 即 可 。 同 理 ，change | 
| 也 可 以 只 修改 数据 类 型 ， 即 语句 中 设置 新 旧 字 段 名 同名 ， 那 么 它 所 实现 的 效果 和 MODIF 是 
一 样 的 。 





13.3.4 ”添加 字段 


缺少 字段 ， MySQL 数据 库 提供 如 下 方法 添加 字段: 
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alter table < 表 名 > add < 新 字段 名 > < 数据 类 型 > [约束 条 件 ] [firstlafter 已 有 字 
段 名 ] ; 

或 者 

ALTER TABLE < 表 名 > ADD < 新 字段 名 > < 数据 类 型 > [约束 条 件 ] [FIRST|AFTER 已 有 字 
段 名 ] ; 

从 上 述 语 句 中 ， 可 以 看 出 “alter table...add” 或 者 “ALTER TABLE...ADD” 为 添加 字段 的 
关键 字 ， 添 加 一 个 字段 必须 得 包括 其 字段 名 、 数 据 类 型 。 约 束 条 件 、 添 加 的 位 置 是 可 选 的 。“ 表 
名 ”表示 需要 添加 字段 的 表 名 称 ， “新 字段 名 ”表示 添加 的 字段 名 ，“ 数 据 类 型 ”表示 添加 字 
段 的 数据 类 型 ，“ 约 束 条 件 ”表示 对 添加 字段 的 约束 限制 ，“firstlafter” 表 示 新 增 字段 存放 的 位 
置 ， 不 指定 位 置 时 ， 默 认 是 添加 在 数据 表 的 最 后 列 。 下 面 分 别 介绍 4 种 例子 用 于 说 明 添 加 字段 过 
程 中 的 不 同情 况 。 


1. 添加 无 约束 条 件 的 字段 


【示例 13-15】 在 学 生 班级 student_class 表 中 添加 一 个 无 约束 的 varchar 类 型 字段 class_name 
(班级 名 称 ) 。 






执行 步骤 如 下 : 
(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “usetest”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 用 语句 “desc student_class”， 查 看 修改 前 的 表 结 构 ， 结 果 如 图 13.24 所 示 
(4) 执行 添加 语句 如 下 : 
ALTER TABLE student class ADD class name varchar(20); 
(5) 检查 字段 是 否 添加 成 功 ， 同 样 使 用 “desc student_class” 查 看 表 student_class， 添 加 后 
的 结果 如 图 13.25 所 示 。 














图 13.25 ”添加 无 约束 条 件 的 字段 
从 图 13.25 中 可 以 看 出 ，class_name 添加 成 功 。 








必 元 | 如 无 特殊 说 明 ， 以 下 例子 的 执行 步骤 的 前 4 步 都 是 一 样 的 ， 只 是 语句 不 一 样 ， 用 的 数据 库 都 
是 test 数据 库 。 
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2. 添加 约束 条 件 的 字段 

【示例 13-16】 在 学 生 班 级 student_class 表 中 添加 一 个 唯一 且 不 能 为 空 的 varchar(13) 类 型 字 
段 stu_no( 学 生 编号 )。 

执行 步骤 与 示例 13-15 一 样 ， 只 是 第 4 步 中 的 执行 添加 语句 如 下 : 

ALTER TABLE student class ADD stu no varchar (13) nut null unique; 


添加 后 的 结果 如 图 13.26 所 示 。 











图 13.26 ”添加 约束 条 件 的 字段 
从 图 13.26 中 ， 可 以 发 现 字 段 stu_no 添加 成 功 。 
3. 添加 字段 目 位 于 表 中 第 一 列 
【示例 13-17】 在 学 生 班级 student_class 表 中 添加 一 个 varchar(13) 类 型 字段 column1， 且 位 于 
第 一 列 。 
执行 步骤 与 示例 13-15 一 样 ， 只 是 第 4 步 中 的 执行 添加 语句 如 下 : 
ALTER TABLE student class RDD column1l varchar (13) first; 


添加 后 的 结果 如 图 13.27 所 示 。 
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图 13.27 添加 字段 位 于 第 一 列 
从 图 中 可 以 看 出 ， 列 columnl 添加 成 功 且 位 于 第 一 列 。 


194 


4. 添加 字段 目 位 于 指定 列 之 后 
【示例 13-18】 在 学 生 班级 student_class 表 中 添加 一 个 varchar(13) 类 型 字段 column2， 且 位 于 
列 stu_no。 
执行 步骤 与 示例 13-15 一 样 ， 只 是 第 4 步 中 的 执行 添加 语句 如 下 : 
ALTER TABLE student class ADD column2 varchar (13) after stu no; 


添加 后 的 结果 如 图 13.28 所 示 。 
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图 13.28 ”添加 字段 位 于 列 stu_no 之 后 
从 图 中 可 以 看 出 ， 列 column2 添加 成 功 且 位 于 列 stu_no 之后。 


13.3.5 ”删除 字段 

前 面 小 节 都 是 介绍 如 何 修改 、 添 加 字段 ， 当 创建 表 时 发 现 多 了 些 字段 ， 就 要 删除 。MySQL 
数据 库 提供 如 下 方法 删除 字段 : 

alter table < 表 名 > drop < 字段 名 > 

或 者 

ALTER TABLE < 表 名 > DROP < 字段 名 > 


从 上 述 语句 中 ， 可 以 看 出 “alter table...drop” 或 者 “ALTER TABLE...DROP” 为 删除 字段 
的 关键 字 ， 语 法 当中 “ 表 名 ”表示 需要 删除 字段 的 表 名 称 ，“ 字 段 名 ”表示 要 删除 的 字段 。 下 面 
以 介绍 删除 student_class 表 中 column2 字段 为 例 。 


【示例 13-19】 删 除 学 生 班 级 student_class 表 中 column2 字段 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “usetest”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 用 语句 “desc student_class”， 查 看 原先 表 结 构 ， 结 果 如 图 13.29 所 示 。 
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图 13.29 查看 student_class 表 结 构 
(4) 执行 删除 语句 如 下 : 
alter table student class drop column2; 


(5) 语句 执行 之 后 ， 检 查 字 段 是 否 删除 成 功 ， 同 样 使 用 “desc student class ”查看 表 
student_class 的 表 结 构 ， 如 图 13.30 所 示 。 
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1 Default 1 Extra ! 


! NULL 
! NULL 
NULL 
NULL 


! NULL 
! NULL 
! NULL 











图 13.30 ”删除 字段 后 的 表 结 术 


与 图 13.29 对 比 ， 能 发 现 少 了 字段 column2， 表 示 删 除 成 功 。 


13.3.6 ”修改 字段 的 排列 位 置 


当 创 建 完 表 之 后 ， 会 发 现 有 些 字段 的 排列 顺序 并 不 是 想 要 的 ， 那 么 就 可 以 通过 更 改 字 段 的 位 
达到 想 要 的 效果 。MySQL 数据 库 提供 如 下 方法 修改 字段 的 排列 位 置 : 
alter table < 表 名 > modify < 字段 1> < 数据 类 型 > first1after< 字 段 2> 
或 者 
ALTER TABLE < 表 名 > MODIFY < 字段 1> < 数据 类 型 > FIRST1RAFTER< 字 段 2> 
从 上 述 语句 中 ， 可 以 看 出 与 修改 字段 类 型 是 一 样 ， 那 么 重点 在 于 FIRSTIAFTER 的 使 用 。 
“ 表 名 ”表示 需要 修改 字段 的 表 名 称 ，“ 字 段 1” 表 示 修 改 位 置 的 字段 名 ，“ 数 据 类 型 ”表示 
“字段 1” 的 数据 类 型 ， “firstlafter” 了 存放 的 位 置 位 于 “字段 2” 之 前 还 是 之 后 ， 















196 





下 面 分 别 介绍 first 和 after 的 使 用 例子 。 
1. 修改 字段 为 表 的 第 一 个 字段 
【示例 13-20】 修 改 学 生 班级 student class 表 中 字段 id 为 第 一 个 字段 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “usetest”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 用 语句 “desc student_class”， 查 看 原先 表 结 构 ， 结 果 如 图 13.30 所 示 。 
(4) 执行 修改 语句 如 下 : 
ALTER TABLE student class modify id int(10) first; 
(5) 语句 执行 之 后 ， 检 查 字 段 是 否 修改 成 功 ， 同 样 使 用 “desc student_class ”查看 表 
student_class 的 表 结 构 ， 如 图 13.31 所 示 。 











图 13.31 修 该 字段 位 于 第 一 列 

从 图 中 可 以 看 出 ， 列 id 添加 成 功 且 位 于 第 一 列 。 
2. 修改 字段 位 置 位 于 指定 列 之 后 

【示例 13-21】 修改 学 生 班级 student_class 表 中 字段 class_id 位 于 列 stu_no 之 后 。 
执行 步骤 如 下 : 

(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 

(2) 使 用 语句 “usetest”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 

(3) 用 语句 “desc student class”， 查 看 原先 表 结 构 ， 结 果 如 图 13.31 所 示 。 

(4) 执行 修改 语句 如 下 : 
ALTER TABLE student class modify class id int(10) after stu no; 
(5) 语句 执行 之 后 ， 检 查 字 段 是 否 修改 成 功 ， 同 样 使 用 “desc student_class” 查 看 表 

student_class 的 表 结 构 ， 如 图 13.32 所 示 。 
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图 13.32 修改 字段 位 于 列 stu_no 之 后 
从 图 中 可 以 看 出 ， 列 class id 修改 成 功 且 位 于 列 stu_no 之 后 。 


13.3.7 ”更 改 表 的 存储 引擎 

第 12 章 介绍 过 存储 引擎 的 基本 概念 以 及 主要 存储 引擎 的 区 别 ， 那 么 假定 默认 的 存储 引擎 不 
满足 应 用 的 要 求 ， 修 改 存储 引擎 就 成 为 必需 的 了 。 在 MySQL 中 ， 提 供 修改 存储 引擎 的 方法 如 下 : 

alter table < 表 名 > ENGINE=< 需 要 的 引擎 名 > 

或 者 

ALTER TABLE < 表 名 > ENGINE=< 需 要 的 引擎 名 > 

从 上 述 语 句 中 ， 可 以 看 出 “alter table...ENGINE” 或 者 “ALTER TABLE...ENGINE” 为 更 改 
存储 引擎 的 关键 字 ， 在 这 其 中 “ENGINE” 必 须 大 写 。 假 设 上 述 例子 中 的 表 t_classl 的 引擎 为 
InnoDB， 要 修改 为 MyISAM 引擎 ， 举 例 说 明 如 下 。 

【示例 13-22】 将 表 t_classl 的 存储 引擎 修改 为 MyISAM。 

执行 步骤 如 下 : 

(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 


(2) 使 用 语句 “use test”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 用 语句 “show create table t_class1\G”， 查 看 当前 的 存储 引擎 ， 结 果 如 图 13.33 所 示 。 
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图 13.33 ”查看 表 t_classl 的 存储 引擎 
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从 图 中 可 以 得 知 表 t_classl 的 存储 引擎 为 nnoDB 。 
(4) 执行 修改 语句 如 下 : 


Alter table t classl ENGINE=MyISAM; 





本 元 | ENGINE 标志 要 大 写 ， 小 写 会 报错 ， 引 擎 的 名 称 也 要 输入 正确 。 | 


(5) 语句 执行 之 后 ， 检 查 是 否 修改 成 功 ， 同 样 使 用 “show create table t_class1\G” 查 看 表 
tablet_classl 的 表 结构 ， 修 改 后 的 结果 如 图 13.34 所 示 。 














图 13.34 ”修改 tclassl 表 引 擎 结果 图 


从 图 13.34 得 知 ， 表 t_classl 的 存储 引擎 已 经 修改 为 MyISAM 存储 引擎 。 


13.3.8 ”删除 表 的 外 键 关联 

在 章节 13.1.3 中 ， 介 绍 了 如 何 添 加 外 键 关 联 ， 当 不 需要 外 键 关 联 时 ， 如 何 去 除 ? MySQL 提 
供 了 如 下 方法 : 

alter table < 表 名 > drop foreign key < 外 键 约束 名 称 >; 

或 者 

ALTER TABLE < 表 名 > DROP FOREIGN KEY < 外 键 约束 名 称 >; 

从 上 述 语句 中 ， 可 以 看 出 “alter table...drop foreign key” 或 者 “ALTER TABLE...DROP 
FOREIGN KEY” 为 删除 表 外 键 关联 的 关键 字 。 下 面 在 表 student_class 中 建立 了 外 键 关联 ， 那 么 
以 删除 表 student_class 的 外 键 关联 为 例 讲述 删除 表 的 外 键 关联 。 

【示例 13-23】 删 除 表 student_class 的 外 键 关联 。 

执行 步骤 如 下 : 

(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 

(2) 使 用 语句 “usetest”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 

(3) 用 语句 “show create table student_class\G”， 查 看 表 的 外 键 关联 情况 ， 结 果 如 图 13.35 
所 示 。 
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图 13.35 查看 表 student class 的 外 键 约束 
从 图 13.35 可 以 看 出 ， 表 student class 有 名 为 “全 _stu_class” 的 外 键 关联 ， 它 关联 到 表 
t_class 的 id 字段 。 
(4) 执行 删除 外 键 约束 语句 如 下 : 
ALTER TABLE student class drop foreign key fk stu class; 


(5) 执行 后 ， 使 用 语句 “show create table student_class\G”， 查 看 其 表 外 键 关联 ， 结 果 如 图 
13.36 所 示 。 








图 13.36 ”删除 表 student_class 外 键 约束 


从 图 13.36 得 知 表 student_class 中 已 经 不 存在 名 称 为 “从 _stu_class” 的 外 键 关 联 ， 表 示 删 除 
成 功 。 


删除 数据 库 表 
删除 数据 库 表 ， 这 是 一 个 “和 危险 ”的 操作 。 删 除数 据 库 表 是 删除 数据 库 中 存在 的 表 ， 万 一 删 
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第 13 章 ”数据 表 的 基本 操作 


除 错误 ， 就 会 给 生产 环境 和 系统 应 用 造成 不 必要 的 麻烦 和 损失 ， 所 以 在 删除 之 前 都 应 该 备份 数据 
或 者 备份 整个 数据 库 ， 这 样 利于 数据 库 恢复 。 

删除 数据 库 表 ， 会 有 两 种 情形 ， 一 种 是 删除 简单 表 ， 一 种 是 删除 关联 的 表 。 下 面 分 别 进 
行 讲述 。 








13.4.1 删除 简单 的 表 


删除 简单 表 ， 即 删除 没有 表 关 联 关系 的 表 ， 这 种 情况 删除 比较 简单 ，MySQL 提供 了 如 下 方 
法 : 


DROP TABLE [IF EXISTS] 表 1， 表 2，.….7 
或 者 
drop table [if exists] 表 1, 表 2,.….; 


从 上 述 语句 中 ， 可 以 看 出 “drop table” 或 者 “DROP TABLE” 为 删除 表 的 关键 字 。 要 删除 
多 张 表 ， 只 需 依 次 写 好 表 名 且 用 逗号 隔 开 。 语 法 中 参数 “IF EXISTS” 是 可 选项 。 如 果 添 加 了 
此 参数 ， 即 使 表 不 存在 ， 执 行 删除 命令 也 不 会 报错 。 下 面 以 例子 说 明 。 

【示例 13-24】 删 除 不 存在 的 表 aaa。 

执行 步骤 如 下 : 

(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 

(2) 使 用 语句 “use test”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 

(3) 执行 删除 命令 : 


drop table aaa; 
执行 结果 如 图 13.37 所 示 。 
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irop table aa 











图 13.37 ”删除 不 存在 的 表 
从 图 中 可 以 看 到 ， 提 示 “Unknown table'testaaa" ”错误 。 
(4) 执行 删除 命令 : 
drop table if exists aaa; 


执行 结果 如 图 13.38 所 示 。 
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图 13.38 ”添加 删除 参数 ifexists 


从 图 13.38 中 可 以 看 出 ， 没 有 提示 错误 ， 而 是 提示 “Query OK ,0 rows affected”， 说 明 语句 
执行 了 ， 但 是 没有 删除 成 功 。 


【示例 13-25】 删 除 多 张 表 t_class1 、studentl 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “usetest”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 用 命令 “show tables” 查 看 现 有 的 表 ， 如 图 13.39 所 示 。 





一 wd Chont 





图 13.39 删除 表 前 查看 表 的 结果 
(4) 执行 删除 命令 : 
drop table t classl,student; 


(5) 语句 执行 后 ， 再 用 命令 “show tables” 查 看 库 中 的 表 ， 如 图 13.40 所 示 。 





ET 一 一】 








图 13.40 ”删除 表 后 查看 表 的 结果 
与 图 13.39 的 比较 得 知 ， 数 据 表 列表 中 已 经 不 存在 t_classl 表 和 student 表 ， 表 示 删 除 成 功 。 


13.4.2 ”删除 关联 表 
删除 关联 表 ， 通 常 是 指 删除 关联 表 中 的 主 表 。 因 为 只 有 删除 主 表 的 情况 下 ， 执 行 删除 命令 才 
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会 报错 ， 删 除 从 表 是 不 会 有 错误 提示 。 下 面 以 例子 进行 说 明 。 
【示例 13-26】 删 除 被 表 student_ class 关联 的 表 t_class。 
执行 步骤 如 下 : 

(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “usetest”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 用 命令 “show tables” 查 看 现 有 的 表 ， 如 图 13.40 所 示 。 


(4) 先 删 除 主 表 试 试 ， 会 有 什么 结果 。 
(5) 执行 删除 命令 


drop table 七 class 


执行 后 ， 命 令 窗口 显示 结果 如 图 13.41 所 示 。 





国 wsQts6Command Line Cient [EX 二 | 








图 13.41 删除 关联 表 错 误 


从 图 中 可 知 ， 直 接 删 除 主 表 失败 ， 因 为 它 的 主键 被 关联 了 。 接 着 操作 ， 先 删除 从 表 中 的 关联 


(6) 用 命令 “show create table student_class” 查 看 外 键 名 称 ， 如 图 13.35 所 示 。 
(7) 删除 子 表 student_class 的 外 键 约束 ， 语 句 如 下 : 


ALTER TABLE student class drop foreign key fk stu class; 
执行 语句 后 ， 将 取消 表 student_class 和 表 t_class 之 间 的 关联 关系 。 

(8) 再 执行 语句 : 

drop table t class; 


(9) 执行 成 功 后 ， 用 语句 “show tables” 查 看 数据 表 列 表 如 图 13.42 所 示 。 
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图 13.42 删除 表 后 的 数据 表 列表 
从 图 中 执行 结果 可 以 看 到 ， 数 据 库 表 中 已 经 不 存在 t_class， 说 明 删 除 成 功 。 
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实战 一 一 数据 库 和 数据 表 的 基本 操作 


前 面 的 章节 对 数据 表 的 基本 操作 做 了 详细 的 介绍 ， 包 括 如 何 创建 表 、 增 加 表 中 字段 的 属性 及 
其 约束 、 如 何 修改 表 中 的 字段 和 字段 类 型 、 如 何 删除 表 ， 相 信 读 者 对 数据 表 的 操作 也 有 所 了 解 ， 
那么 本 节 用 一 个 组 织 部 门 关系 对 这 些 操 作 进 一 步 说 明 ， 加 深 对 数据 表 操 作 的 印象 。 

首先 ， 创 建 数据 库 org， 按 表 13.4 和 表 13.5 的 表 结 构 在 org 库 中 创建 2 个 数据 表 dept (部门 
表 ) 和 emp (员工 表 ) 。 


表 13.4 dept 表 结构 





字段 名 数据 类 型 
dept id int(10) 
dept_name varchar(20) 
address varchar(100) ? 
[aipeode | in | 
ml ml 































蕊 | 蕊 | 蕊 马 | 间 且 a 






否 


表 13.5 emp 表 结构 









字段 名 数据 类 型 主键 
rr Ta El 
| emp name | vachaco | 在 | 奋 | 
[ex jn [i | 
[mobie | iD | 二 | | 
| pe may | | 
| bb jdeime [在 
















birth 


| dtid | ml 
address varchar(100) 
varchar(20) 
varchar(50) 


(1) 登录 MySQL 数据 库 
打开 MySQL5.6 Command Line Client， 输 入 数据 库 密 码 ， 如 图 13.43 所 示 。 
人 mand Line Cient SEE 















station 




















remark 























图 13.43 在 MySQL5.6 Command Line Client 中 输入 数据 库 密码 
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(2) 创建 数据 库 org 
创建 数据 库 org， 其 语句 如 图 13.44 所 示 。 创 建成 功 后 ， 输 入 语句 “use org”， 就 可 以 在 org 
数据 库 中 创建 表 ， 如 图 13.45 所 示 。 


国 MySQL 5.6 Command Line Client | 





EATE DATABA' 
-1 row af 








图 13.44 ”创建 数据 库 org 





国 MySQL 5.6 Command Line Client 呈 | es 














图 13.45 使 用 数据 库 org 
(3) 创建 表 dept 
创建 表 dept， 其 语句 如 图 13.46 所 示 。 创 建成 功 后 ， 使 用 命令 “show create table deptG”， 
查看 创建 结果 ， 如 图 13.47 所 示 。 





园 MysQL 5.6 Command Line client 


ysql> CREATE TRBLE dept 
pt_id 


dept rcha | 


telephone 
PRIMARY 











图 13.46 创建 表 dept 


> DEPAULT NULL. 
DEFAULT NILL, 











图 13.47 查看 创建 结果 
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(4) 创建 表 emp 
创建 表 emp， 其 语句 如 图 13.48 所 示 。 创 建成 功 后 ， 使 用 命令 “show tables” 查 看 数据 库 中 
的 表 ， 如 图 13.49 所 示 。 











图 13.48 ”创建 表 emp 





国 MysQL 5.6 command Line Clent ll 


ql> show tabh 
! Tables_in_org 
! dept 
1 emp 














图 13.49 查看 数据 库 中 的 表 


从 图 13.49 可 以 看 出 ， 数 据 库 中 已 经 创建 好 了 dept 和 emp 两 个 数据 表 。 要 检查 表 的 结构 是 
否 正 确 ， 可 以 使 用 命令 “desc 表 名 ”来 查看 ， 如 图 13.50 所 示 。 





1 1 LL 
1 MULL 











图 13.50 查看 表 dept 和 emp 的 表 结 构 


从 图 13.50 可 以 看 出 ， 创 建 的 结构 符合 表 13.4 和 表 13.5 的 要 求 。 
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(5) 将 表 emp 的 mobile 字段 修改 到 address 后 面 。 
修改 字段 位 置 ， 其 语句 如 下 : 
ALTER TABLE emp MODIFY mobile int(11) AFTER address; 


使 用 命令 “desc emp” 查 看 修改 后 的 表 结 构 ， 如 图 13.51 所 示 。 





图 MsQts 











图 13.51 命令 查看 表 emp 
从 图 13.51 可 以 看 出 ，mobile 字段 已 经 修改 在 address 后 面 。 
(6) 将 表 emp 的 address 字段 更 名 为 emp_address。 
修改 字段 名 ， 其 语句 如 下 : 
ALTER TABLE emp CHANGE address emp address varchar (100) ; 


使 用 命令 “desc emp” 查 看 修改 后 的 表 结 构 ， 如 图 13.52 所 示 。 














图 13.52 更 名 后 的 表 结 构 
从 图 13.52 可 以 看 出 ，address 字段 已 经 更 名 为 emp_address。 


(7) 修改 sex 字段 ， 数 据 类 型 为 varchar(1) 且 不 能 为 空 。 
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修改 字段 类 型 ， 其 语句 如 下 : 
ALTER TABLE emp MODIFY sex varchar(1) NOT NULL; 


使 用 命令 “desc emp” 查 看 修改 后 的 表 结 构 ， 如 图 13.53 所 示 。 


NOT MULLS 











图 13.53 修改 类 型 后 的 表 结构 


从 图 13.53 可 以 看 出 ，sex 字段 类 型 已 经 修改 为 varchar(1)， 且 null 列 显 示 为 NO， 表示 该 列 
不 能 有 空 值 。 


(8) 删除 字段 phone。 
删除 字段 ， 其 语句 如 下 : 
ALTER TABLE emp DROP phone; 


使 用 命令 “desc emp” 查 看 删除 后 的 表 结 构 ， 如 图 13.54 所 示 。 





国 wsQL56ca 








图 13.54 ”删除 字段 后 的 表 结构 
从 图 13.54 可 以 看 出 ，phone 字段 已 经 不 在 表 结 构 中 ， 删 除 字段 成 功 。 
(9) 增加 字段 favoriate， 数 据 类 型 为 VARCHAR(50)。 


增加 字段 ， 其 语句 如 下 : 


208 


ALTER TABLE emp ADD favoriate VRRCHRAR (50) 


使 用 命令 “desc emp” 查 看 增加 后 的 表 结 构 ， 如 图 13.55 所 示 。 从 图 中 可 以 看 出 ，favoriate 
字段 已 经 在 表 结构 中 且 数 据 类 型 为 VARCHAR(50)， 增 加 字段 成 功 。 





图 MYSQL 56 Commar = 


yeql> ALTER TABLE 











图 13.55 增加 字段 后 的 表 结构 
(10) 删除 表 dept 
创建 表 emp 时 ， 设 置 了 表 的 外 键 ， 该 表 关 联 了 dept 表 的 主键 。 在 删除 表 dept 表 时 ， 要 先 删 
除 子 表 emp 的 外 键 约束 ， 才 能 删除 主 表 。 
@ 删除 emp 表 的 外 键 约束 ， 其 语句 如 下 : 
ALTER TABLE emp DROP FOREIGN KEY fk emp dept; 
删除 外 键 约束 成 功 ， 如 果 没有 其 他 外 键 关 联 ， 就 可 以 删除 dept 主键 。 
@ 删除 表 dept， 其 语句 如 下 : 
DROP TABLE dept; 


使 用 命令 “show tables”， 查 看 数据 库 中 的 表 ， 结 果 如 图 13.56 所 示 。 





国 MySQL 5.6 Command Line client 一 一 | 


8-98 sec》 








图 13.56 删除 表 后 的 数据 库 列 表 
从 图 13.56 中 ， 可 以 看 出 数据 库 已 经 不 存在 表 dept。 


(11) 修改 表 emp 存储 引擎 为 MyISAM 
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修改 表 存 储 引 擎 ， 其 语句 如 下 : 


ALTER TABLE emp ENGINE=MyISAM; 


重 元 ENGINE 一 定 要 大 写 。 





使 用 命令 “show create table emp\G” 查 看 修改 引擎 后 的 表 结 构 ， 如 图 13.57 所 示 。 





国 MySQL 5.5 Command Line Chent = | ke 















图 13.57 查看 修改 引擎 后 的 表 结 构 
从 图 13.57 可 以 看 出 ， 表 emp 的 存储 引擎 已 经 修改 为 MyISAM。 
(12) 将 表 emp 名 称 修 改 为 emp_info 
修改 表 名 称 ， 其 语句 如 下 : 
ALTER TABLE emp RENAME emp info; 


使 用 命令 “show tables” 查 看 数据 库 表 列 表 ， 如 图 13.58 所 示 。 





| 





图 13.58 更 名 表 emp 
从 图 13.58 可 以 看 出 ， 表 emp 名 称 已 经 修改 为 emp_info。 
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前 一 章 介绍 了 数据 库 中 的 基本 操作 : 创建 表 、 查 看 表 结构 、 修 改 表 结构 、 删 除 表 结 构 ， 使 读 
者 对 于 数据 库 表 操作 有 基本 的 了 解 。 在 数据 库 中 重 中 之 重 还 是 对 数据 的 操作 ， 包 括 数据 的 增加 、 
删除 、 修 改 、 查 询 ， 本 章 将 逐一 介绍 MySQL 数据 库 中 关于 数据 的 操作 。 

本 章 将 详细 介绍 数据 的 基本 操作 ， 包 括 : 插入 数据 、 修 改 数据 、 删 除数 据 、 查 询 数据 。 通 过 
本 章 的 介绍 可 以 掌握 数据 的 基本 操作 ， 在 MySQL 命令 行 下 对 数据 进行 操作 ， 包 括 单列 或 者 多 列 
的 数据 查询 ， 使 用 聚合 函数 查询 、 连 接 查询 、 子 查询 。 如 果 读 者 熟悉 MySQL 命令 行 下 的 数据 操 
作 ， 那 么 对 于 MySQL 图 形 界面 的 操作 也 会 触 类 旁 通 。 


1 4 ;Wl 数据 


添加 数据 就 是 为 数据 库 中 的 表 添 加 新 数据 ， 数 据 表 中 有 了 数据 ， 才 能 进行 各 种 操作 ， 
MySQL 数据 库 插入 数据 大 致 可 以 分 为 3 种 情形 ， 对 所 有 字段 插入 数据 、 指 定 表 字段 插入 数据 、 
插入 多 条 数据 。 下 面 我 们 一 一 介绍 。 
14.1.1 为 所 有 字段 添加 数据 

为 表 的 所 有 字段 添加 数据 ，MySQL 数据 库 提供 的 方法 如 下 : 


地 时 时 
| | 


从 上 述 语句 中 ， 可 以 看 出 “insert into ..values” 或 者 “INSERT INTO ...VALUES” 为 添加 数 
据 的 关键 字 。 其 中 ，table name 是 插入 目标 表 名 ，column,column2.. 表 示 插 入 目标 表 的 字段 ， 





vall,val2... 表 示 对 应 的 字段 值 。 

本 章 使 用 的 数据 库 是 上 节 提 到 的 org 库 ， 用 的 样 例 表 是 dept 表 ， 具 体 的 创建 过 程 参 加 13.5 

【示例 14-1]】 在 dept 表 中 ， 插 入 一 条 新 数据 ，dept id 值 为 1，dept name 值 为 “银行 总 
行 ”，address 值 为 “北京 金融 街 XXX 号 ”，zipcode 值 为 “100000”，telphone 值 为 
“01022334455”。 

执行 步骤 如 下 : 

(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 

(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 

(3) 在 执行 语句 前 ， 可 以 先 用 语句 “select * from dept ”查询 表 中 的 数据 ， 作 为 对 比 。 其 语 
句 如 下 : 

SELECT * FROM dept; 


运行 结果 如 图 14.1 所 示 。 





{ 国 wsoL56 Command Line Clert sey | 





图 14.1 插入 前 的 结果 
(4) 执行 插入 的 SQL 语句 如 下 : 


INSERT INTO dept (dept id,dept name,address ,zipcode,telephone) 
VALUES (1, ' 银 行 总 行 ',' 北 京 金融 街 XXX 号 ', 100000,1022334455)， 


(5) 命令 执行 结束 后 ， 用 语句 “select* from dept ”查询 表 中 的 数据 。 如 图 14.2 所 示 。 





[was 






ty 











图 14.2 插入 后 的 结果 


从 图 14.2 可 以 看 出 ， 在 插入 表 dept 时 ， 指 定 了 表 中 的 所 有 字段 ， 为 每 个 字段 插入 值 。 从 2 
张 表 对 比 可 以 看 出 ， 插 入 成 功 。 








是 | 插入 的 字段 顺序 可 以 不 是 创建 表 的 字段 顺序 ， 只 要 保证 值 的 顺序 四 列 字段 的 顺序 一 样 就 行 ， 
[ 否则 可 能 出 现 值 类 型 四 定义 的 类 型 不 一 致 导 至 无 法 括 入 值 。 
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在 使 用 INSERT 插入 数据 时 ， 若 插入 指定 表 的 列表 项 为 空 ， 则 插入 的 值 必须 和 数据 表 中 字段 
定义 时 的 顺序 一 样 ， 否 则 会 报 列 数 不 够 的 错误 。 下 面 以 例子 说 明 。 


【示例 14-2】 在 dept 表 中 ， 插 入 一 条 新 数据 ，dept id 值 为 2，dept name 值 为 “北京 分 
行 ”，address 值 为 “北京 国贸 XXX 号 ”，zipcode 值 为 “110000 ”，telphone 值 为 
“01022334466”。 














执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 执行 的 SQL 语句 如 下 : 


INSERT INTO dept VALUES (2, ' 北 京 分 行 ',110000,01022334466，' 北 京 国贸 XXX 
ep 


或 者 





中 


INSERT INTO dept VALUES (2, ' 北 京 分 行 ', 110000,01022334466); 


| 


可 以 看 出 ， 语 句 中 故意 将 地 址 放置 最 后 列 或 者 少 了 列 值 ， 执 行 语句 ， 其 结果 如 图 14.3 所 示 。 





国 MysQL 5.6 Command Line aient 


wysql》 INSERT INIO dept UALUES 《2- -119889.B1822334456 


366 《HY98B》 rrect integer valuez 


|: 


图 14.3 少 字 段 插入 结果 


从 图 14.3 中 可 以 看 出 ， 两 种 语句 都 插入 错误 ， 一 个 提示 “Incorrect integer value”， 一 个 提 
示 “Column count doesnm'tmatch value count at row” 列 数 不 匹配 。 


(4) 执行 的 正确 SQL 语句 如 下 : 


INSERT INTO dept VAEUESO (20 de 
',110000,01022334466); 





(5) 执行 完 语句 ， 用 “select * from dept” 查 询 结 果 ， 如 图 14.4 所 示 。 





加 wsQ dine Co sg 








图 14.4 不 指定 列 的 插入 结果 
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vSQL 网 站 开发 从 和 零 开 始 (视频 教学 版 ) 


从 图 14.4 可 以 看 出 。 数 据 库 中 增加 了 一 条 dept id 为 2 的 数据 ， 表 明 插 入 语 名 成功。 从 第 3 
步 和 第 4 步 的 语句 可 以 看 出 ， 在 没有 指定 列 且 只 有 列 值 的 顺序 时 ， 值 列表 要 为 每 一 个 字段 指定 
值 ， 并 且 这 些 值 的 顺序 必须 与 建 表 时 定义 的 字段 顺序 一 致 且 类 型 也 要 一 致 ， 否 则 就 会 报错 。 


14.1.2 ”指定 表 字 段 添 加 数据 
对 表 指 定 字 段 添 加 数据 时 ， 指 定 的 字段 值 必须 符合 字段 数据 类 型 ， 没 有 指定 的 字段 ， 其 值 要 
么 是 默认 值 要 么 是 字段 值 允许 空 值 。 下 面 还 是 以 表 dept 为 例 进 行 说 明 。 
【示例 14-3】 在 dept 表 中 ， 插 入 一 条 新 数据 ， 指 定 dept_id 值 为 3，dept name 值 为 “北京 十 
里 河 支行 ”，address 值 为 “北京 十 里 河 XXX 号 ”。 
执行 步骤 如 下 : 
(1) 同 示例 14-1 


(2) 同 示例 14-1。 
(3) 执行 SQL 语句 如 下 : 


INSERT INTO dept (dept id,dept name,address) 
VALUES (3， ' 北 京 十 里 河 支行 ',' 北京 十 里 河 XXX 号 '); 











图 14.5 对 指定 字段 插入 值 


从 图 14.5 中 可 以 看 出 ， 插 入 记录 成 功 ，dept_id、dept name、address 分 别 插入 了 指定 值 ， 没 
有 指定 默认 值 的 字段 ，MySQL 数据 库 会 定义 成 NULL， 但 这 前 提 是 创建 表 时 定义 的 字段 允许 为 
室 ， 和 否则 插入 时 会 报错 。 如 果 定 义 了 默认 值 ， 则 插入 时 数据 库 会 自动 设置 默认 值 。 以 表 dept 为 
例 ， 为 表 dept 增加 一 个 备注 remark 字段 ， 数 据 类 型 为 varchar(20)， 默 认 值 是 “xxx 银行 ”。 

【示例 14-4】 在 dept 表 中 ， 插 入 一 条 新 数据 ，dept id 值 为 4，dept name 值 为 “北京 xxx 银 
行 分 钟 寺 支行 ”，address 值 为 “北京 分 钟 寺 XXX 号 ”。 

执行 步骤 如 下 : 


(1) 同 示例 14-1。 
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(2) 同 示例 14-1 。 
(3) 先 执行 增加 字段 ， 其 语句 如 下 : 


ALTER TABLE dept ADD remark varchar(20) default 'xxx 银 行 ' ; 
(4) 执行 插入 的 SQL 语句 如 下 : 


INSERT INTO dept (dept id,dept name,address) 
VALUES (4, ' 北 京 xxx 银行 分 钟 寺 支行 ',' 北 京 分 钟 寺 XXX 号 ') ; 


(5) 执行 完 语句 ， 用 语句 “select* from dept;” 查 询 表 中 的 数据 ， 其 结果 如 图 14.6 所 示 。 











图 14.6 ”对 指定 字段 插入 值 并 指定 默认 值 
从 图 14.6 中 可 以 看 出 ， 插 入 记录 成 功 并 且 id、name、address 插入 了 指定 值 ， 为 remark 字段 
定义 了 默认 值 “xxx 银行 ”， 数 据 库 自动 设置 。 


14.1.3 ”添加 多 条 记录 
前 2 个 小 节 描 述 了 为 表 插 入 单条 数据 ， 而 在 实际 的 应 用 中 ， 经 常会 同时 添加 多 条 数据 ， 
MySQL 提供 如 下 方式 : 


INSERT INTO table name (Columnl,column2,….) VALUES (valuel,value2,...), 
(valuel,value2,...) 


或 者 
INSERT INTO table name VALUES (valuel,value2,..), (valuel,value2,...) 
或 


Insert into table name(columnl,column2,...) values (valuel,value2,...), 
(valuel,value2,...) 


或 者 


inset into table name values (valuel,value2,..), (valuel,value2,...) 











本 元 | 不 指定 添加 列表 时 ， 添 加 的 列 值 一 定 要 与 创建 表 的 字段 对 应 。 
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上 述 语 句 中 ， 添 加 的 关键 字 跟 单条 是 一 样 的 ， 区 别 在 于 插入 多 条 时 ， 字 段 值 列表 
(valuel,value2,.….) 用 逗号 分 开 。 插 入 时 允许 指定 字段 列表 也 可 以 不 指定 字段 列表 ， 这 跟 单条 插 
入 是 一 样 的 ， 同 样 不 指定 字段 列表 时 的 限制 跟 单条 一 样 。 下 面 以 dept 表 为 例 ， 描 述 插入 多 条 数 
据 时 ， 指 定 列 与 不 指定 列 的 例子 。 
【示例 14-5】 在 dept 表 中 ， 在 dept_id、name、address 指定 列 且 指 定 插入 值 ， 同 时 插入 4 条 
记录 。 
执行 步骤 如 下 





(1) 同 示例 14-1。 
(2) 同 示例 14-1。 
(3) 执行 SQL 语句 如 下 : 
INSERT INTO dept (dept id,dept name,address) 
VALUES (5, ' 北 京 xxx 银行 潘 家 园 支行 '， "北京 十 里 河 XXX 号 ') ， 
(6, "北京 xxx 银行 国贸 天 阶 支行 ',' 北 京 国贸 天 阶 XXX 号 ')， 


(7, ' 北 京 xxx 银行 东 三 环 支行 ',' 北 京东 三 环 XXX 号 ')， 
(8, "北京 xxx 银行 望京 南 支行 '，' 北京 望京 南 XXX 号 '); 


(4) 执行 完 语句 ， 用 语句 “select* from dept;” 查 询 表 中 的 数据 ， 其 结果 如 图 14.7 所 示 。 





QL SS ns ES 





图 14.7 对 指定 字段 插入 多 条 数据 


从 图 14.7 中 可 以 看 出 ，dept 表 增 加 了 插入 语句 中 的 4 条 记录 ， 而 没有 指定 remark 值 是 因为 
它 有 默认 值 。 

假如 ， 在 插入 多 条 数据 时 ， 不 指定 列表 ， 但 是 插入 的 类 型 又 不 对 应 ， 在 插入 时 会 报 如 图 14.8 
所 示 的 错误 。 因 为 name 类 型 指定 的 是 varchar 类 型 ， 而 在 插入 时 没有 用 单 引 号 引起 来 ， 所 以 在 
插入 时 就 会 报 类 型 不 对 应 。 
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图 14.8 ”插入 错误 类 型 
下 面 介绍 不 指定 列 ， 但 为 每 个 字段 指定 值 的 方式 插入 。 


【示例 14-6】 在 dept 表 中 ， 不 指定 列 ， 同 时 插入 2 条 记录 。 
执行 步骤 如 下 : 
(1) 同 示例 14-1。 
(2) 同 示例 14-1 。 
(3) 执行 SQL 语句 如 下 : 
INSERT INTO dept 
VALUES (9,， 北 京 xxx 银行 木 棵 园 支行 "北京 木 标 园 XXX 号 


"110000,01022334488,' 木 标 园 ') ， 
(10, ' 北 京 xxx 银行 方 庄 支行 '，' 北京 方 庄 XXX 号 ', 110000,01022334477, ' 方 庄 '); 


(4) 执行 完 语 句 ， 用 语句 “select * from dept;” 查 询 表 中 的 数据 ， 其 结果 如 图 14.9 所 示 。 
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图 14.9 不 指定 字段 插入 多 条 数据 


从 图 14.9 与 图 14.7 对 比 ， 可 以 看 出 dept 表 中 增加 了 2 条 记录 。 从 插入 语句 中 可 以 看 出 ， 插 
入 的 字段 值 类 型 与 字段 是 一 一 对 应 的 ， 这 在 插入 时 一 定 要 注意 ， 否 则 就 会 出 错 。 


更 新 数据 


在 上 一 节 中 ， 介 绍 了 数据 的 添加 操作 ， 相 信 读 者 对 如 何 添 加 数据 有 所 了 解 ， 添 加 完 数据 后 发 
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现 值 不 正确 ， 又 想 只 更 新 某 些 字段 的 值 ， 在 MySQL 中 提供 了 如 下 更 新 方式 : 

update table name set columnl=valuel,column2=value2..columnn=valuen 
[where condition]; 

或 者 

UPDATE table name SET columnl=valuel,column2=value2..columnn=valuen 
[WHERE condition]; 

从 上 述 语句 中 ， 可 以 看 出 “update ..set ”或 者 “UPDATE ...SET” 为 更 新 数据 的 关键 字 。 
column1、column2、column 是 要 更 新 的 表 字 段 名 ，valuel、value2、valuen 是 对 应 的 指定 字段 更 
新 r 具体 值 ，condition 是 更 新 数据 的 条 件 ， 可 选项 。 更 新 的 时 候 ， 通 常 是 一 批 数据 或 者 某 条 数 
据 ， 以 更 新 dept 表 中 的 数据 为 例 ， 如 何 更 新 一 条 数据 记录 或 者 多 条 数据 记录 。 





【示例 14-7】 在 dept 表 中 ， 更 新 dept id 值 为 8 的 记录 ， 将 dept_name 字段 值 改 为 “北京 
xxx 银行 宋 家 庄 支 行 ”，address 字段 值 改 为 “北京 宋 家 庄 XXX 号 ”。 
执行 步骤 如 下 : 





(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 

(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 

(3) 执行 修改 的 SQL 语句 如 下 : 

update dept set dept name=' 北 京 xxx 银行 宋 家 庄 支行 ', address=' 北 京 宋 家 庄 
XXX 号 ' where dept id=8; 

(4) 执行 完 语句 ， 可 以 用 语句 “select * from dept where dept_id=8;” 查 询 表 中 的 数据 ， 其 结 
果 如 图 14.10 所 示 。 
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图 14.10 ”执行 修改 后 的 结果 


从 图 14.10 中 可 以 看 出 ，dept id 等 于 8 的 数据 中 的 dept_name 和 address 字段 的 值 已 经 成 功 
被 修改 为 指定 值 。 

如 上 是 指定 主键 值 的 情况 ， 那 么 数据 只 更 新 一 条 。 更 新 指定 的 一 批 数据 ， 该 如 何 呢 ? 以 dept 
表 中 更 新 zipcode 为 null 的 数据 ， 将 其 值 都 更 改 为 10001 为 例 讲解 更 新 指定 的 一 批 数据 。 


【示例 14-8】 在 dept 表 中 ， 更 新 zipcode 为 null 的 数据 ， 将 其 都 更 改 为 10001。 
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执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 在 执行 SQL 语句 前 ， 使 用 查询 语句 查看 当前 的 数据 ， 如 图 14.11 所 示 。 


select * from dept where zipcode is null ; 











图 14.11 执行 修改 前 的 结果 
(4) 执行 修改 的 SQL 语句 如 下 : 
update dept set zipcode=10001 where zipcode is null ; 


(5) 执行 完 语句 ， 用 语句 “select* from dept where zipcode=10001;” 查 询 表 中 的 数据 ， 其 
结果 如 图 14.12 所 示 。 











图 14.12 执行 修改 后 的 结果 


将 图 14.11 与 图 14.12 对 比 可 以 看 出 ， 原 先 zipcode 值 为 空 的 列 全 部 都 变 为 10001 值 ， 说 明 
更 新 列表 成 功 。 

综 上 所 述 ， 更 新 数据 时 如 果 只 更 新 某 条 数据 ， 需 增加 条 件 来 限定 这 一 数据 : 如 果 不 加 条 件 ， 
则 语句 更 新 的 就 是 一 批 数据 量 ， 如 果 想 更 新 指定 的 一 批 数 据 ， 则 条 件 中 需 指定 这 一 批 数 据 。 所 以 
更 新 的 时 候 ， 请 注意 条 件 的 使 用 ， 以 免 更 新 出 错 。 
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删除 数据 


两 节 分 别 介绍 了 添加 数据 和 更 新 数据 ， 当 有 和 元 余 数据 或 者 错误 数据 要 进行 删除 时 ， 
MySQL 数据 库 提 供 了 如 下 方法 删除 数据 。 
DELETE FROM TABLE NAME [WHERE condition] 

或 者 

delete from table name [where condition]; 

或 

truncate table table name 

或 者 

TRUNCATE TABLE TABLE NAME; 

从 上 述 语句 中 ， 可 以 看 出 “delete from ...” 或 者 “DELETE FROM ...” 或 者 “truncate 
table ...” 或 者 “TRUNCATE TABLE ...” 为 更 新 数据 的 关键 字 。TABLE_NAME 或 table_name 
表示 要 删除 数据 的 表 名 ，condition 表示 要 删除 的 条 件 ， 是 可 选项 ， 如 果 不 加 WHERE condition， 
则 表示 删除 表 中 的 所 有 数据 。TRUNCATE 与 delete 的 区 别 在 于 是 否 可 以 回 滚 ，delete 删除 可 以 
回 滚 ，truncate 删除 不 能 回 滚 ， 那 么 在 执行 truncate 时 效率 就 会 高 些 。 仍 以 dept 表 中 的 数据 为 例 
进行 说 明 如 何 删除 数据 。 

【示例 14-9】 在 dept 表 中 ， 删 除 dept_id 为 8 的 记录 。 

执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 在 执行 SQL 语句 前 ， 可 以 使 用 查询 语句 查看 当前 的 数据 ， 如 图 14.13 所 示 。 


Select * from dept where dept id=8 ，; 





Qs 











图 14.13 ”执行 删除 前 的 结果 
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(4) 执行 删除 的 SQL 语句 如 下 : 


delete from dept where dept id=8 


日 


(5) 执行 完 删除 语句 ， 用 语句 “select * from dept where dept_id=8” 查 询 表 中 的 数据 


果 如 图 14.14 所 示 。 
= 
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ysql> delete fron de 





图 14.14 ”执行 删除 后 的 结果 
从 图 14.14 与 图 14.13 比较 可 以 看 出 ，dept_id 值 为 8 的 数据 不 存在 了 ， 说 明 删除 数据 成 功 。 


下 面 描述 删除 整 张 表 的 数据 。 


【示例 14-10】 删 除 表 dept 中 所 有 的 记录 。 


执行 步骤 如 下 : 
(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org ”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 在 执行 SQL 语句 前 ， 可 以 使 用 查询 语句 查看 当前 的 数据 ， 如 图 14.15 所 示 。 


select * from dept ;，; 











图 14.15 ”执行 删除 前 的 结果 


(4) 执行 删除 的 SQL 语句 如 下 : 


delete from dept ; 


或 者 
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truncate table dept; 


(5) 执行 完 删除 语句 ， 用 语句 “select * from dept” 查 看 ， 其 结果 如 图 14.16 所 示 。 
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图 14.16 ”执行 删除 后 的 结果 
从 图 14.16 与 图 14.15 对 比 可 以 看 出 ， 表 dept 的 数据 都 为 空 ， 说 明 删 除数 据 成 功 。 


查询 数据 


前 面 3 个 章节 讲述 了 如 何 添 加 数据 、 更 新 数据 以 及 删除 数据 ， 这 为 如 何 查询 数据 提供 了 基 
础 。 查 询 数据 是 使 用 数据 库 跟 应 用 之 间 一 项 重要 的 工具 ， 它 是 沟通 数据 库 与 应 用 的 桥梁 。 本 节 将 
详细 讲述 如 何 进行 数据 查询 ， 包 括 简 单 查询 、 复 杂 查 询 、 关 联 查询 、 多 条 件 查询 ， 使 用 聚合 函数 
查询 ， 使 用 子 查询 等 。 


14.4.1 ”基本 查询 语句 


基本 的 查询 语句 ， 这 是 查询 中 的 基本 ，MySQL 提供 的 方式 如 下 : 


SELECT 字段 列表 FROM < 表 1>,< 表 2>，…- 
[WHERE < 表达 式 > ] 
[GROUP BY <definition>] 
[HAVING <expression> [{<expression>}]] 
[ORDER BY <definition>] 
[LIMIT [<offset>,] <row count>] 


从 上 述 语句 中 ， 可 以 看 出 “select .from ”或 者 “SELECT ...FROM” 为 查询 数据 的 基本 形 
式 ，WHERE 、GROUPBY、HAVING、ORDER BY、LIMIT 关键 字 都 是 可 选项 ， 其 含义 如 下 : 


@ WHERE < 表达 式 > 表示 要 过 滤 掉 哪些 数据 ， 哪 些 是 需要 的 数据 。 

@ 。 GROUP BY <definition> 表示 MySQL 查询 数据 将 按照 指定 的 字段 分 组 显示 。 

@ ORDERBY <definition> 表示 MySQL 查询 数据 将 按照 指定 的 字段 排列 顺序 显示 ， 多 个 
字段 之 间 用 过 号 隔 开 ， 排 序 有 升序 (asc ) 和 降序 (desc ) 之 分 。 

@ HAVING <expression> [{<expression>}] 也 表示 要 过 滤 掉 哪 些 数据 ， 哪 些 是 需要 的 数 
据 ， 它 与 where 的 区 别 在 于 having 可 以 与 聚合 函数 使 用 ， 而 where 条 件 不 可 以 。 
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@ LIMIT [<offset>,] <row count> 表示 查询 出 的 数据 数量 以 及 从 什么 位 置 开 始 查询 ，offset 
表示 从 什么 位 置 开 始 ，row count 表示 显示 的 数量 。 


查询 的 语句 中 ， 关 键 字 虽 比较 繁多 ， 但 含义 都 浅显 易 懂 ， 可 要 熟练 运用 它们 ， 还 有 待 后 续 章 
节 的 讲解 ， 这 里 读者 们 先 有 个 大 致 的 印象 即 可 。 


14.4.2 ”查询 所 有 字段 
查询 所 有 字段 就 是 将 表 中 所 有 的 字段 都 在 结果 列表 中 显示 ，MySQL 数据 提供 了 2 种 方法 ， 
-种 是 使 用 “*” 通 配 符 ， 另 外 一 种 是 列 出 表 中 所 有 的 字段 。 下 面 分 别 介 绍 这 2 种 方法 。 
1. 使 用 ”通配符 查询 所 有 字段 
利用 “*” 通 配 符 查询 表 的 数据 是 查询 语句 最 简单 的 方法 ， 其 基本 形式 如 下 : 
select * from table name; 
下 面 在 表 books 中 插入 多 条 数据 ， 以 books 中 的 数据 作为 查询 例子 。 
【示例 14-11】 从 books 表 中 查询 所 有 字段 的 数据 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 

(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 执行 查询 语句 如 下 : 

Select * from books; 


执行 SQL 语句 后 ， 如 图 14.17 所 示 。 

















图 14.17 通配符 “* ”查询 数据 








从 图 14.17 中 可 以 看 出 ， 使 用 “* ”通配符 ， 将 返回 所 有 的 列 ， 十 分 清晰 。 


2. 列 出 所 有 的 字段 查询 
另外 一 种 查询 所 有 字段 的 方法 是 ， 在 select 后 列 出 表 中 所 有 的 字段 ， 并 用 逗号 分 隔 。 这 种 方 
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式 在 与 应 用 结合 的 时 候 使 用 的 较 多 ， 因 为 可 以 减少 检索 时 间 ， 通 配 符 在 不 知道 列 名 的 情况 下 使 
用 。 改 造 例 子 14-11，SQL 语句 如 下 : 
select id,name,author,price from books; 
执行 的 结果 跟 示 例 14-11 的 结果 是 一 样 的 。 当 然 也 可 以 更 改 查 询 出 的 顺序 ， 例 如 语句 是 : 
Select name,id,price,author from books; 


执行 的 结果 就 跟 图 14.17 不 一 样 了 ， 如 图 14.18 所 示 。 
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sal》 select nane.id. 











图 14.18 更改 查询 顺序 
从 图 14.18 中 可 以 看 出 ， 查 询 的 结果 是 按照 指定 的 顺序 显示 ， 而 图 14.16 是 按照 表 创建 时 的 


顺序 显示 。 


14.4.3 ”查询 指定 字段 

查询 指定 字段 ， 是 指 查 询 指定 的 某 些 字段 ， 通 常 是 在 列 数 比较 多 ， 而 只 是 想 查看 某 几 列 的 数 
据 时 使 用 。 查 询 多 个 字段 ， 跟 查询 所 有 字段 中 第 二 种 方式 一 样 ， 只 需要 SELECT 后 面 将 多 个 字 
段 用 逗号 分 隔 开 即 可 ， 其 格式 如 下 : 


select columnl,column2,..column from table name; 





【示例 14-12】 从 books 表 中 查询 字段 name、price， 即 所 有 的 书 名 称 和 价格 ，SQL 语句 如 下 : 
select name,price from books; 


执行 SQL 语句 后 ， 如 图 14.19 所 示 。 
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图 14.19 查询 单一 字段 


从 图 14.18 可 以 看 出 ， 输 出 结果 只 显示 了 books 表 中 name、price 字段 下 的 所 有 数据 ， 而 没 
有 显示 id，author 的 数据 。 


14.4.4 查询 指定 记录 


查询 指定 记录 是 指 查 询 数据 库 中 指定 的 某 些 数据 ， 它 主要 是 用 于 数据 库 中 包含 有 大 量 的 数据 
时 ， 因 为 数据 量 太 大 ， 查 询 出 的 数据 不 足以 反映 出 系统 的 要 求 ， 所 以 需要 指定 记录 过 滤 掉 不 需要 
的 数据 。 这 里 先 介 绍 用 where 进行 条 件 过 滤 。 形 式 如 下 : 


SELECT columnl,column2,..column FROM table name 
WHERE condition 


或 者 


select columnl,column2,..column FROM table name 
where condition 


仍 以 books 中 的 数据 为 例 ， 查 询 价格 为 89 的 书籍 。 
【示例 14-13】 查 询 价 格 为 89 的 书籍 。 
执行 步骤 如 下 : 


(1) 同 示例 14-1。 
(2) 同 示例 14-1。 
(3) 查询 语句 如 下 : 


select name,price from books where price=89; 


执行 SQL 语句 后 ， 其 如 图 14.20 所 示 。 
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图 14.20 查询 价格 为 89 的 数据 


从 图 14.20 可 以 看 出 ， 输 出 结果 显示 了 books 表 满 足 价格 为 89 的 数据 。 


格 元 因为 在 创建 表 books 时 ， 定 ) 
询 ， 当 SQL 语句 是 select name:price from books where 


名 时 ，SQL 是 按照 等 值 站 
price=77.15 查询 出 的 数据 就 是 空 的 ， 那 么 要 更 改 精 度 类 型 或 者 更 改 字段 类 型 为 double， 这 | 


样 查询 出 的 数据 就 是 正确 的 ) 





字段 price 为 float 类 型 ， 没 有 指定 其 精度 类 型 ， 所 以 在 查询 语 | 












【示例 14-14】 查 询 名 称 为 “hadoop” 的 书籍 ，SQL 语句 如 下 : 
select name,price from books where name='hadoop'; 


执行 SQL 语句 后 ， 如 图 14.21 所 示 。 
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图 14.21 查询 名 称 为 hadoop 的 数据 
从 图 14.21 可 以 看 出 ， 输 出 结果 只 显示 books 表 中 满足 名 称 为 “hadoop” 的 数据 。 
【示例 14-15】 查 询 价格 范围 为 45 至 70 之 间 的 书籍 ，SQL 语句 如 下 : 


select name,price from books where price >=45 and price <=70; 


执行 SQL 语句 后 ， 如 图 14.22 所 示 。 





= | 
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14.22 ”查询 价格 为 45 至 70 之 间 的 书籍 
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第 14 章 数据 的 基本 操作 


从 图 14.22 可 以 看 出 ， 输 出 的 价格 均 是 在 45 与 70 之 间 的 书籍 
综 上 所 述 ，where 条 件 的 判断 符 可 以 归纳 为 表 14.1 所 示 。 





表 14.1 where 条 件 判断 符 


相等 ， 如 果 字 段 类 型 是 数值 ， 则 不 加 引号 ;如果 是 字符 串 类 型 ， 需 要 加 入 引号 
不 相等 ， 如 果 字 段 类 型 是 数值 ， 则 不 加 引号 ;如果 是 字符 串 类 型 ， 需 要 加 入 引号 




















< 一 小 于 ， 小 于 等 于 ， 一 般 可 用 于 数值 或 者 时 间 上 的 判断 
>> | 大 于 ， 大 于 等 于 ， 一 般 可 用 于 数值 或 者 时 间 上 的 判断 
between ”| 介 于 两 个 值 之 间 ， 一 般 可 用 于 数值 或 者 时 间 上 的 判断 
in | 指定 范围 内 的 条 件 ， 一 般 可 用 于 数值 或 者 时 间 上 的 判断 




















14.4.5 带 IN 关键 字 的 查询 
从 表 14.1 中 可 得 知 ，MySQL 提供 了 指定 范围 内 的 条 件 查询 ， 其 形式 如 下 : 


Select column1l, column2,.…column from table name where column 
in(condition]l,codition2); 


或 者 


SELECT column]l, column2, .column from table name WHERE column 
in(condition]l,codition2); 


如 上 描述 中 ，column1,column2,.….column 是 要 查询 的 字段 ，table_ name 是 查询 的 表 名 ， 
condition1,condition2 分 别 是 2 个 条 件 用 去 号 分 开 ， 当 满足 条 件 范围 内 的 一 个 值 即 为 匹配 。 那 么 它 
们 与 “大 于 等 于 ， 小 于 等 于 ”有 什么 区 别 ， 先 来 看 下 面 的 例子 。 


【示例 14-16】 查 询 价格 为 43 和 68 的 书籍 ，SQL 语句 如 下 : 





select name,price from books where price in (45,68) 


执行 SQL 语句 后 ， 其 结果 列表 如 图 14.23 所 示 。 
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图 14.23 查询 价格 为 45 和 68 的 书籍 


从 图 14.23 可 以 看 出 ， 所 输出 的 书籍 为 指定 条 件 的 书籍 。 包 括 两 个 端点 的 值 。 
若 加 个 关键 字 NOT， 则 表示 查询 不 是 在 范围 内 的 数据 。 
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【示例 14-17】 查 询 价格 不 为 45 和 68 的 书籍 ，SQL 语句 如 下 : 





select name,price from books where price not in (45,68); 


执行 SQL 语句 后 ， 如 图 14.24 所 示 。 
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图 14.24 查询 价格 不 为 45 和 68 的 书籍 


从 图 14.24 可 以 看 出 ， 所 输出 的 书籍 为 指定 条 件 的 书籍 ， 不 在 45 和 68 价格 范围 内 。 
从 上 面 的 例子 可 以 看 出 ，in 关键 字 查 询 是 等 值 查询 。 





了 元 | 在 in 范围 查询 时 ， 由 于 字段 是 float 类 型 ， 精 度 会 被 省 略 ， 所 以 上 述 语句 中 车 查询 范围 为 | 
(45.50,68.54 ) 等 同 于 (45,68)。 所 以 一 般 而 言 都 把 类 型 更 改 成 decimal 标准 数据 类 型 。 所 以 下 面 | 
的 例子 将 字段 price 类 型 更 改 为 decimal(5,2) 








14.4.6 带 BETWEEN AND 的 范围 查询 


BETWEEN AND 也 是 用 来 查询 范围 内 的 数据 ， 它 用 来 查询 2 个 范围 内 的 数据 ， 如 果 字 段 值 
满足 查询 条 件 ， 则 返回 满足 条 件 的 数据 。 它 与 IN 关键 字 的 区 别 在 于 BETWEEN AND 是 范围 内 
查询 ，IN 是 等 值 查询 。 下 面 以 例子 说 明 。 


【示例 14-18】 查 询 价格 为 45 和 68 的 书籍 ，SQL 语句 如 下 : 
select name,price from books where Price between 45 and 68; 


执行 SQL 语句 后 ， 如 图 14.25 所 示 。 




















14.25 查询 价格 为 45 到 68 之 间 的 书籍 
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从 图 14.25 可 以 看 出 ， 返 回 结果 包含 了 价格 从 45 到 68 之 间 的 数据 ， 并 且 45 和 68 也 在 返 世 
的 结果 列表 中 ， 很 明显 between 是 匹配 范围 内 的 所 有 值 ， 包 括 2 端点 值 。 属国 14.23 相 比 多 了 数 
据 ， 可 以 明显 得 知 IN 是 等 值 查询 而 BETWEEN AND eic i 留 2 个 端点 值 。 

类 似 的 ， 若 加 个 关键 字 NOT， 则 表示 查询 不 在 范围 内 的 数 














【示例 14-19】 查 询 价 格 不 为 45 和 68 之 间 的 书籍 ，SQL 语句 如 下 : 
select name,price from books where price not between 45 and 68; 


执行 SQL 语句 后 ， 如 图 14.26 所 示 。 








图 14.26 ”查询 价格 不 为 45 和 68 的 书籍 
从 图 14.26 可 以 看 出 ， 返 回 的 记录 是 小 于 45 或 大 于 68 的 书籍 。 其 结果 与 语句 : 
select name,price from books where price < 45 or price > 68; 


执行 结果 一 样 。 


14.4.7 带 LIKE 的 字符 匹配 查询 

带 like 的 字符 匹配 查询 ， 从 字面 上 理解 like， 就 是 “类 似 ” 的 含义 。 在 SQL 语句 中 ， 它 的 
含义 就 是 包含 的 意思 ， 通 常 使 用 like 查找 匹配 的 数据 要 跟 通 配 符 “%” 或 者 “_” 一 起 使 用 。 
“%” 表 示 任 意 多 个 字符 ，“_” 表 示 任 意 一 个 字符 ， 下 面 分 别 介绍 这 2 种 的 使 用 方法 。 

1. 使 用 “%” 通 配 符 

【示例 14-20】 查 询 字 段 name 中 所 有 以 hr? 字 母 开头 的 书籍 。 

执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 执行 查询 语句 如 下 : 


select name,price from books where name like ‘'h%'; 


执行 SQL 语句 后 ， 如 图 14.27 所 示 。 
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图 14.27 查询 以 中 ”字母 开头 的 书籍 








从 图 14.27 可 以 看 出 ， 返 回 的 记录 是 以 “h” 开 头 的 数据 ， 不 管 中 ”后 面 有 多 少 字符 ， 只 要 
符合 “h” 字 符 开 头 就 可 以 。 











【示例 14-21】 查 询 字 段 name 中 包含 a' 字 母 的 书籍 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 执行 查询 语句 如 下 : 
select name,price from books where name like '%a%'; 
执行 SQL 语句 后 ， 如 图 14.28 所 示 。 
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图 14.28 查询 包含 “a” 字 母 的 书籍 


从 图 14.28 可 以 看 出 ， 返 回 的 记录 是 包含 “a” 字 母 的 数据 ， 只 要 符合 包含 有 字母 “a” 的 数 
据 就 可 以 。 

【示例 14-22】 查 询 字 段 name 中 以 “o” 开头，“ 全 ” 字 结 尾 的 书籍 。 

执行 步骤 如 下 : 

(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 

(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 

(3) 执行 查询 语句 如 下 : 


select name,price from books where name like 'o% 全 '; 


执行 SQL 语句 后 ， 如 图 14.29 所 示 。 
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图 14.29 查询 以 “o” 开 头 ，“ 全 ” 字 结 尾 的 书籍 








从 图 14.29 可 以 看 出 ， 返 回 的 记录 是 以 “o” 开 头 ， “全” 字 结 
综 上 所 述 ，“%” 是 匹配 任意 长 度 的 字符 ， 即 指定 位 置 任意 
下 面 介绍 “_” 通 配 符 使 用 情况 ， 看 下 跟 “%” 通 配 符 的 区 别 。 
2. 使 用 下 划 线 “_” 通 配 符 

下 划 线 通配符 与 百 分 号 通配符 使 用 方法 一 样 。 先 看 例子 14-24 。 





虹 的 数据 。 
目 字符 ， 包 括 零 字 符 。 

















【示例 14-23】 查 询 字段 name 中 以 “h” 开头， 且 小” 后 面具 有 5 个 字母 的 书籍 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 执行 查询 语句 如 下 : 


select name,price from books where name like 'h | 


执行 SQL 语句 后 ， 如 图 14.30 所 示 。 











图 14.30 查询 以 “h” 开头， 且 “h” 后 面 只 有 5 个 字母 的 书籍 
从 图 14.30 可 以 看 出 ， 返 回 的 记录 是 以 “h” 开 头 ， 且 “h” 后 面 只 有 5 个 字母 的 书籍 ， 如 果 





其 他 记录 中 有 以 “h” 开 头 ， 但 是 匹配 字符 长 度 不 为 5 的 ， 也 不 在 返回 的 结果 中 。 从 例子 中 能 看 
出 “ ”通配符 与 “%” 通 配 符 区 别 在 于 下 划 线 只 能 匹配 任意 一 个 字符 ， 而 百 分 号 是 任意 多 个 字 


符 。 

















下 划 线 要 匹配 多 个 字符 ， 则 需要 使 用 数量 相等 的 ”通配符 。 


14.4.8 查询 空 值 


查询 空 值 是 要 查询 数据 库 中 某 字段 值 为 空 的 数据 。MySQL 数据 库 提供 查询 空 值 的 方法 如 下 : 


select columnl,column2,.. from table where column is null; 


231 





关键 字 是 is null， 从 方法 上 看 
空 ， 则 使 用 is not null。 下 面 以 例子 进行 说 明 。 
【示例 14-24】 查 询 字 段 price 为 空 的 书籍 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 执行 查询 语句 如 下 : 


select id, name,price from books where price is null; 





执行 SQL 语句 后 ， 如 图 14.31 所 示 。 
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图 14.31 查询 price 为 空 的 书籍 


并 不 是 为 0 或 者 空 的 字符 串 ， 而 是 未 知 的 数据 。 如 果 是 非 


从 图 14.31 可 以 看 出 ， 返 回 的 记录 是 price 为 null 的 书籍 ， 满 足 查 询 的 条 件 。 如 果 查 询 的 是 


price 不 为 null， 则 使 用 is not null 字句 来 查询 ， 如 例子 14-26 所 示 。 
【示例 14-25】 查 询 字段 price 不 为 空 的 书籍 。 
执行 步骤 如 下 : 
(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 执行 查询 语句 如 下 : 
select id, name,price from books where price is not null; 


执行 SQL 语句 后 ， 如 图 14.32 所 示 。 











图 1432 查询 price 不 为 空 的 书籍 
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从 图 14.32 可 以 看 出 ， 返 回 的 记录 是 price 不 为 null 的 书籍 。 








14.4.9 带 AND 的 条 件 查询 

带 AND 的 查询 条 件 ， 这 个 在 查询 时 经 常用 到 ， 而 且 通 常 是 多 条 件 限制 的 查询 ， 这 样 查询 的 
结果 更 加 符合 要 求 并 且 准 确 。 数 据 库 中 使 用 AND 操作 符 来 连接 多 个 并 列 查 询 条 件 ， 只 有 满足 所 
有 查询 条 件 的 数据 才 会 被 返回 ， 其 作用 就 是 “与 ”的 关系 。 以 表 books 为 例 ， 查 询 作 者 是 “ 肖 
**” 并 且 书 的 价格 大 于 40 的 书籍。 


【示例 14-26】 查 询 字 段 author 为 “ 肖 **” 的 作者 ， 并 且 书 的 价格 大 于 40 的 书籍 。 











执行 步骤 如 下 : 

(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 

(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 

(3) 执行 查询 语句 如 下 : 

select id, name,price,author from books where author=' 肖 **' and 


price>40; 


执行 SQL 语句 后 ， 其 结果 如 图 14.33 所 示 。 
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图 14.33 查询 肖 ** 作 者 且 书 价 大 于 40 的 书籍 











从 图 14.33 可 以 看 出 ， 返 回 的 记录 是 字段 author 为 “ 肖 **” 作 者 ， 并 且 书 的 价格 大 于 40 的 
书籍 。 从 SQL 语句 中 可 以 看 出 where 子 句 分 为 两 个 部 分 ， 前 一 段 指定 作者 是 “ 肖 **”， 后 半 段 
指定 价格 为 大 于 40， 要 同时 满足 这 2 个 条 件 才能 被 显示 出 来 。 还 可 以 再 过 加 个 字段 书 名 为 
“hadoop” 来 限制 查询 条 件 ， 例 如 14-28 例子 。 

【示例 14-27】 查 询 字 段 author 为 “ 肖 **” 作 者 ， 并 且 书 的 价格 大 于 40， 书 名 为 “hadoop” 
的 书籍 ，SQL 语句 如 下 : 

select id, name,price,author from books where author=' 肖 **' and 
price>40 and name='hadoop'7 


执行 SQL 语句 后 ， 如 图 14.34 所 示 。 
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图 14.34 查询 肖 ** 作 者 且 书 价 大 于 40 和 书 名 为 hadoop 的 书籍 
图 14.34 与 图 14.32 对 比 可 以 看 出 数据 列表 少 了 一 条 ， 只 显示 书 名 为 hadoop 的 数据 。 


14.4.10” 带 OR 的 条 件 查 询 


在 查询 记录 时 ， 有 “与 ”的 关系 就 会 有 “或 ”的 关系 ， 数 据 库 中 使 用 OR 操作 符 来 连接 
“或 ”关系 的 查询 条 件 ， 只 要 要 满足 其 中 任意 -个 查询 条 件 的 数据 就 会 被 返回 。 
对 例子 14-27 进行 改造 ， 这 样 便于 说 明 OR 跟 AND 的 差别 。 


【示例 14-28】 查 询 字 段 author 为 “ 肖 **” 作 者 或 者 书 的 价格 大 于 40 的 书籍 ，SQL 语句 如 


select id, name,price,author from books where author=' 骨 **' or 
price>40; 


执行 SQL 语句 后 ， 如 图 14.35 所 示 。 











图 14.35 查询 肖 ** 作 者 或 书 价 大 于 40 的 书籍 








从 图 14.35 可 以 看 出 ， 返 回 的 记录 是 字段 author 为 “ 肖 **” 作 者 ， 或 者 书 的 价格 大 于 40 的 
书籍 。 从 SQL 语句 中 可 以 看 出 where 子 句 分 为 两 个 部 分 ， 前 一 段 指定 作者 是 “ 肖 **”， 后 半 自 
指定 价格 为 大 于 40， 满 足 其 中 任何 1 个 条 件 就 能 被 显示 出 来 。 








14.4.11 ”查询 结果 不 重复 


在 查询 数据 列表 时 ， 可 能 存在 很 多 重复 的 字段 数据 ， 但 是 当 统计 数据 的 时 候 并 不 
重复 的 数据 。MySQL 数据 库 提 供 了 DISTINCT 关键 字 进 行 过 滤 查 询 。 语 法 的 基本 形式 为 : 
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select distinct column1 from table name; 
或 者 
SELECT DISTINCT column1l FROM table name” 


从 上 述 语句 中 ， 可 以 看 出 “distinct” 或 者 “DISTINCT” 为 排除 不 重复 的 关键 字 。 仍 以 表 
books 为 例 ， 查 询 不 同 作者 的 书籍 ， 这 里 先 不 统计 数量 ， 如 例子 14-29。 





【示例 14-29】 查 询 字 段 author 且 作 者 不 重复 的 书籍 。 








执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org”， 选 择 数 据 库 ， 已 选择 可 以 省 略 。 
(3) 执行 查询 语句 如 下 : 
select DISTINCT author ,id, name,price from books ; 


执行 SQL 语句 后 ， 如 图 14.36 所 示 。 
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图 14.36 查询 字段 author 且 作者 不 重复 的 书籍 


从 图 14.36 可 以 看 出 ， 返 回 的 记录 是 字段 author 不 重复 的 书籍 ， 每 行 都 不 一 样 ，SQL 语句 把 
null 值 也 当 作 是 不 同 值 输 出 。 
BE SN 
本 元 | DISTINCT 放 的 位 置 必须 是 第 一 列 ， 否 则 会 SQL 会 报错 ERROR 1064 (42000): You have mn| 
error in your SQL syntax; check the manual thatcorresponds to your MYSQL server version foor the 
| Tight syntax to use near 'DISTINCT id, name,price from books'atline 1。 











14.4.12 ”对 查询 结果 排序 


在 SQL 语句 中 ， 有 时 需要 对 查询 结果 进行 排序 ， 例 如 查询 员工 工资 从 大 到 小 或 者 从 小 到 大 
排序 ， 更 新 日 期 按 升序 或 者 降序 排列 。 在 MySQL 中 使 用 关键 字 Order by 进行 排序 ， 可 以 按 字 
段 的 升序 〈asc) 或 者 降序 (desc) 排列 ， 并 且 多 字段 同时 使 用 ， 多 字段 用 去 号 分 隔 开 。 其 基本 
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形式 如 下 : 


select columnl,column2,... from 
columnl1, column2,...column; 

或 : 

SELECT column]l,column2,... FROM 


columnl,column2,...column; 


或 者 指定 排序 顺序 : 


table name 


table name 


select columnl, column2,... from table name 
desclasc,column2 desclasc ,..column desclasc; 
SELECT columnl1, column2,... FROM table name 


DESCI|ASC, column2 DESCIASC ,..column DESCIASC; 


order 


ORDER 


order by 


ORDER BY 


by columnl 


BY columnl 


从 上 述 语 名 中 ， 可 以 看 出 “order by ...desclasc” 或 者 “ORDER BY .. DESCIASC” 为 排序 的 
关键 字 。 我 们 以 查询 书籍 并 按照 价格 的 降序 为 例 进行 说 明 如 下 。 


【示例 14-30】 查 询 书籍 并 按照 价格 的 降序 显示 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 


(2) 使 用 语句 “use org”， 选 择 数 据 库 ， 已 选择 可 以 省 略 。 


(3) 执行 查询 语句 如 下 : 


select author ,id, name,price from books order by price desc ; 


执行 SQL 语句 后 ， 如 图 14.37 所 示 。 
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图 14.37 查询 书籍 并 按照 价格 的 降序 显示 


从 图 14.37 可 以 看 出 ， 返 回 的 记录 是 按照 指定 的 降序 价格 进行 排序 。 同 样 ， 可 以 对 多 字段 指 
定 排序 ， 例 如 ， 指 定 id 字段 是 升序 排序 ， 价 格 是 降序 ， 那 么 SQL 语句 是 按照 从 左 到 右 的 顺序 进 
行 排序 显示 ， 先 是 id 字段 是 升序 ， 而 后 再 按照 价格 降序 排序 ， 例 如 图 14.38 所 示 。 但 这 样 SQL 
语句 就 进行 了 二 次 排序 ， 会 影响 查询 速率 ， 因 此 在 应 用 当中 ， 尽 量 减少 多 字段 排序 ， 以 提高 查询 
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图 14.38 ”查询 书籍 按照 指定 的 多 顺序 显示 





区 导 | 默认 的 情况 下 查询 数据 按照 字母 升序 进行 排序 ， 数 字 是 按照 数值 的 大 小 升序 排序 。 


14.4.13 ”分 组 查询 

何 为 分 组 ? 即将 数据 结构 按照 某 一 字段 或 多 个 字段 进行 归 类 分 组 。 通 常 在 统计 查询 语句 中 经 
常 使 用 ， 例 如 统计 不 同 作者 的 作品 数量 ， 统 计 不 同 部 门 中 的 总 员工 数量 。 在 MySQL 中 ， 其 基本 
形式 如 下 : 


SELECT column .…， 聚合 函数 FROM table name GROUP BY column ..... [HAVING < 
条 件 表达 式 >] 

或 者 

select column .…., 聚 合 函数 from table name group by column ..... [having < 
条 件 表达 式 >] 


从 上 述 语 句 中 ， 可 以 看 出 “group by” 或 者 “GROUP BY” 为 分 组 查询 的 关键 字 。GROUP 
BY 后 面 的 字段 名 必须 与 SELECT 中 的 字段 名 一 致 ，HAVING< 条 件 表 达 式 > 是 分 组 中 的 查询 条 
件 ， 只 有 满足 表达 式 条 件 结果 才能 被 显示 ，HAVING 只 能 是 分 组 之 后 才 出 现 的 条 件 查询 ， 这 就 
有 别 于 where 关键 字 。 下 面 分 别 说 明 分 组 查询 的 3 种 情况 ， 简 单 分 组 、 使 用 HAVING 分 组 、 对 
分 组 排序 。 


1. 简单 分 组 


简单 分 组 实质 是 最 简单 的 统计 功能 ， 一 般 而 言 都 是 跟 聚 合 函 数 一 起 使 用 ， 例 如 : MAXO、 
MINO、COUNTO、SUM0O、AVG0 等 聚合 函数 。 





【示例 14-31】 显 示 每 个 作者 的 作品 总 数 。 
执行 步骤 如 下 : 


(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
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(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 执行 查询 语句 如 下 : 

select author ,count(*) 
执行 SQL 语句 后 ， 如 图 14.39 所 示 。 


图 MYSQL 5.6 Command Line Clent 


from books group by author; 











图 14.39 每 个 作者 的 作品 总 妆 


author 表示 作者 ，count(*) 表示 作者 的 作品 数 ，group by 字句 对 数据 分 组 。 


查询 结果 显示 ， 
个 例子 进行 改造 ， 统 计 作品 数 大 于 1 的 作 


这 是 最 简单 的 分 组 ， 按 某 个 列 进行 分 类 统计 。 下 面 对 这 
者 ， 这 就 要 用 到 HAVING 过 滤 条 件 。 

2. 使 用 HAVING 分 组 

【示例 14-32】 查 询 作 品 数 大 于 1 的 作者 ，SQL 语句 如 下 : 


select author ,count (name) from books group by author HAVING 


count (name) >1; 


执行 上 述 语 句 后 ， 如 图 14.40 所 示 。 
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图 14.40 查询 作品 数 大 于 1 的 作者 
查询 结果 显示 ， 作 者 “ 肖 **#” 的 作品 数 大 于 1， 满 足 HAVING 条 件 ， 所 以 显示 在 结果 中 。 
再 来 看 个 例子 ， 查 询 书 价格 小 于 60 元 ， 作 品 数 大 于 1 的 作者 。 





【示例 14-33】 查 询 书 价格 小 于 60 元 ， 作 品 数 大 于 1 的 作者 ，SQL 语句 如 下 : 


from books where price <60 group by 





select author ,count (name) 
author HAVING count (name)>1; 
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执行 上 述 语句 后 ， 结 果 列表 如 图 14.41 所 示 。 
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图 1441 书 价 小 于 60 元， 作品 数 大 于 1 的 作者 
从 结果 可 以 看 出 ， 没 有 符合 的 数据 显示 。 
从 上 述 2 个 例子 中 ， 我 们 可 以 得 出 如 下 结论 : 
@ 使 用 HAVING 时 ， 必 须 是 分 组 。 
@ where 与 HAVING 同时 出 现时 ，WHERE 的 优先 级 高 于 HAVING。 
有 时 需要 对 结果 进行 排序 ， 那 么 就 需要 用 到 order by 这 个 关键 字 ， 例 如 对 作品 数 按 降 序 排列 
查询 。 下 面 介绍 下 ORDER BY 的 使 用 方法 。 
3. 与 ORDER BY 一 起 使 用 
【示例 14-34】 查 询 作者 的 书籍 总 价 大 于 100 的 作者 ， 并 按 降 序 排序 。 
执行 步骤 如 下 : 
(1) 登录 MySQL 命令 行 ， 已 登录 可 以 省 略 。 
(2) 使 用 语句 “use org”， 选 择 数据 库 ， 已 选择 可 以 省 略 。 
(3) 先 执行 不 使 用 order by 的 查询 语句 如 下 : 
select author ,sum(price) from books group by author HAVING sum(price)>100; 
执行 上 述 语句 后 ， 其 结果 如 图 14.42 所 示 。 图 中 并 没有 asc 关键 字 ， 但 默认 也 是 price 的 升序 
排列 。 





国 MysQL s6 Command Line client (= | © le 

















图 14.42 书籍 总 价 大 于 100 的 作者 
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可 以 看 出 图 中 列 出 书籍 总 价 大 于 100 的 作者 ， 但 在 返回 的 结果 中 sum(price) 列 是 没有 按照 
- 定 的 顺序 显示 。 
(4) 添加 order by 关键 字 的 查询 语句 ， 改 造 SQL 语句 如 下 : 


select author ,sum(price) from books group by author HAVING sum(Price)>100 
order by sum(Price) asc; 


执行 上 述 语句 后 ， 其 结果 如 图 14.43 所 示 。 
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图 14.43 书籍 总 价 大 于 100 的 作者 


可 以 看 出 图 中 列 出 书籍 总 价 大 于 100 的 作者 ， 并 且 按 照 指定 的 升序 排列 总 价 。 综 上 所 述 ， 可 
以 看 出 GROUP BY 按照 作者 进行 分 组 ，SUM0O) 函 数 返 回 总 的 书 价格 ，HAVING 对 分 组 数据 进行 
过 滤 ， 最 后 使 用 ORDER BY 进行 排序 。 


14.4.14 ”LIMIT 限制 查询 
当 数 据 量 是 千 万 级 别 时， 那么 查询 出 所 有 的 结果 是 费时 而 且 也 不 现实 ， 那 么 这 个 时 候 就 要 用 
到 分 页 查询 或 者 叫 限 制 查询 。 在 MySQL 中 ， 用 关键 字 limit 来 限制 查询 。 其 基本 形式 如 下 : 
limit [位 置 , ] row_num 
或 者 
LIMIT [位 置 ] ，ROW_NUM 
从 上 述 语句 中 ， 可 以 看 出 “limit...row_num” 或 者 “LIMIT...ROW_NUM ”为 添加 数据 的 关键 


字 。 第 一 个 “位 置 ”表示 MySQL 从 哪 一 行 开 始 查询 ， 是 可 选项 ， 不 指定 则 默认 是 从 第 一 条 开始 查 
询 ，“row_num” 表 示 显 示 记 录 数 量 。 以 books 表 中 查询 从 第 4 条 开始 ， 查 询 $ 条 数据 为 例 。 


【示例 14-35】 在 表 books 中 ， 使 用 LIMIT， 返 回 从 第 4 个 记录 开始 ， 查 询 5 条 记录 ，SQL 
语句 如 下 : 





select author ,price from books LIMIT 3,5; 


执行 上 述 语 名 后， 如 图 14.44 所 示 。 
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第 14 章 ”数据 的 基本 操作 




















图 14.44 返回 第 4 个 记录 开始 ， 记 录 长 度 为 5 


从 图 中 可 以 看 出 ， 语 名 返回 从 第 4 条 记录 开始 之 后 的 5 条 记录 。 语 句 中 第 一 个 数字 “3” 表 
示 从 第 4 行 开始 ， 第 二 个 数字 5 表示 返回 的 行 数 。 在 MySQL 中 ， 位 置 标 记 是 从 0 开始 ， 第 一 条 
的 位 置 是 0， 第 二 条 的 位 置 是 1， 依次 类 推 。 这 就 跟 JAVA 中 的 数组 下 标 一 样 。 





实战 演练 1 一 一 记录 的 添加 、 更 新 和 删除 










本 章 重点 讲解 了 数据 库 中 数据 的 添加 、 更 新 、 删 除 以 及 查询 这 4 个 大 模块 。 这 4 大 模块 构成 
了 学 习 数 据 库 的 入 门 基 础 ， 也 是 与 应 用 之 间 形 成 关系 的 桥梁 ， 文 4 大 模块 是 数据 库 工程 师 的 


基础 。 所 以 我 们 仍 以 实例 为 基础 ， 从 数据 表 创建 开始 一 步 步 带 着 读者 回顾 下 所 有 的 知识 点 ， 由 于 
内 容 较 多 ， 分 成 2 个 实例 ， 本 小 节 先 介绍 数据 的 增加 、 删 除 、 修 改 。 
创建 表 products ， 其 表 结构 及 表 中 的 数据 ， 见 表 14.2 和 表 14.3 所 示 。 


表 14.2 products 表 结构 


字段 说 明 。 数据 类 型 是 否 主键 



















pid 产品 编码 | int(11) 
p_name 产品 名 称 | varchar(30) 
productor | varchar(30) 





price 
prod date 


Temark 














varchar(100) 
int(11) 
varchar(100) 










kc num 
prod address 














生产 地 址 


表 14.3 ”products 表 数据 











productor prod date prod address 
福建 达 利 2016-11-10 | 福建 达 利 食品 福建 达 利 
胖 胖 山 棒 2016-10-10 | 沈阳 胖 胖 | 235 | 沈阳 胖 胖 
四 川 酒鬼 | 4. 201611-01 | 四 川 酒鬼 | | 四 川 酒鬼 
洽 洽 食 品 2016-08-15 | 福建 治 洽 福建 治 洽 
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( 续 表 ) 





























productor price prod date kc_num prod address 
葵花 子 洽 洽 食品 3.56 2016-11-13 | 福建 治 洽 300 福建 治 洽 
6 | 花生 油 鲁 花 花生 | 7868 | 2016-10-09 | 山东 鲁 花 广 | 40 | 山东 鲁 花 广 
7 ”| 党 香肠 老 干 香肠 | 1836 | 2016-11-11 | 哈尔滨 老 干 ”| 55 | 哈尔滨 老 干 
操作 过 程 如 下 : 
(1) 按照 表 14.2 中 的 表 结 构 创 建 数据 表 products。 创 建 语句 如 图 14.45 所 示 。 
图 Ms [~ /ss 









图 14.45 创建 表 products 
从 图 中 最 后 一 个 语句 可 以 看 出 ， 创 建 表 products 成 功 。 


(2) 将 表 14.3 中 的 数据 插入 到 表 products 表 中 ， 可 以 使 用 不 同 的 方法 插入 数据 ， 在 插入 之 
前 可 以 先 查 询 表 中 的 数据 ， 如 图 14.46 所 示 。 
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[IT | 








图 14.46 ”查询 products 表 中 的 数据 量 


从 图 中 结果 可 以 看 出 数据 为 0。 下 面 分 3 种 方法 插入 数据 : 指定 所 有 字段 名 、 不 指定 字段 
名 、 插 入 多 条 语句 。 


@ ”指定 所 有 字段 名 ， 插 入 语句 如 下 : 


INSERT into products(p id,p name,productors,price,prod date,remark, 
kc num,prod address) 
VALUES (1, ' 达 利 元 ',' 福 建 达 利 ' ,23 .78, '2016-11-10',' 福 建 达 利 食品 ', 200, ' 福 
建 达 利 ') ; 


执行 完 ， 运 行 结果 如 图 14.47 所 示 。 
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图 14.47 全 字段 插入 
@ 不 指定 字段 名 ， 插 入 语句 如 下 : 
INSERT into products 
VALUES (2, ' 山楂 片 '"，' 胖 胖 山楂 ',54.67 ， '2016-10-10'， 
235,“' 沈 阳 胖 胖 ' ) 


执行 完 ， 运 行 结果 如 图 14.48 所 示 。 





图 14.48 不 指定 字段 插入 


"沈阳 胖 胖 ' ， 





横 寺 | 不 指定 字段 名 时 ， 自 动 增加 的 列 除非 有 默认 值 ， 否 则 也 需要 指定 值 


@ ”同时 插入 多 条 数据 ， 插 入 语句 如 下 : 


INSERT INTO products 
VALUES 
(3, ' 酒 鬼 花生 ' ，' 四 川 酒鬼 ' ,4 .56 , '2016-11-01', ' 四 川 酒鬼 '， 


158 ,' 四 川 酒 


bd 

(4, ' 香 瓜 瓜 子 '，' 浴 治 食 品 ' ,7.56 ,'2016-08-15', ' 福 建 治 治 '， 230，' 福建 洽 
Er 

(5, 黄花 子 "， “，' 治 治 食 品 '， 3.56 ”,;'2016-11-13'，' 福 建 治 治 '，300 ,' 福 
建 治 治 ')， 


(6, ' 花 生 油 '， “' 鲁 花花 生 '，78.68 ，'2016-10-09',，' 山 东 鲁 花 厂 '， 


鲁 花 厂 ')， 


(7，' 效 香肠 '， '" 老 干 香肠 '， 18.36 ，"'2016-11-11'，' 哈 尔 滨 老 干 '， 


滨 少 和 中 3 


执行 完 ， 运 行 结果 如 图 14.49 所 示 。 


40，' 山 东 


55,' 险 尔 
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图 14.49 不 指定 字段 多 条 插入 





从 图 14.49 最 后 显示 的 记录 中 可 以 看 出 ，5 条 数据 全 部 增加 成 功 。 可 以 用 语句 : 
Select * from products 


查询 表 中 的 全 部 数据 ， 执 行 结果 如 图 14.50 所 示 。 





图 wysaQ， 








图 14.50 ”查询 products 表 数据 


从 图 14.50 中 可 以 看 出 ， 数 据 全 部 被 新 增 成 功 。 
(3) 修改 “ 洽 洽 食品 ”厂商 生产 的 食品 ， 将 其 价格 降价 2 元 。 执 行 的 语句 如 下 : 
update products set price=price-2 where productors=' 浴 滩 食 品 '; 


执行 的 结果 如 图 14.51 所 示 。 
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图 14.51 更 新 价格 


从 图 14.51 中 可 以 看 出 ， 成 功 更 新 2 条 语句 。 用 语句 : 


Select * from products 
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查询 表 中 的 全 部 数据 ， 执 行 结果 如 图 14.52 所 示 。 














图 14.52 ”查询 products 表 数 据 
将 图 14.52 与 图 14.50 相 比 可 以 看 出 ， 洽 洽 食 品 的 价格 降 了 2 元 ， 说 明 语 句 更 新 成 功 。 
(4) 修改 名 为 “ 达 利 元 ”的 食品 ， 将 其 价格 更 改 为 27.58， 并 且 将 生产 地 址 修改 为 “福建 泉 
州 达 利 元 ”。 执 行 的 语句 如 下 : 


update products set price=27.58， prod address=' 福建 泉州 达 利 元 ' where 
p_name=' 达 利 元 '; 


在 执行 前 ， 先 查询 下 当前 的 记录 ， 如 图 14.53 所 示 。 


Pi 








图 14.53 ”修改 前 的 结果 


执行 修改 语句 后 ， 运 行 结果 如 图 14.54 所 示 。 
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图 14.54 更 新 操作 
从 图 14.54 中 可 以 看 出 ， 成 功 更 新 1 条 语句 。 再 用 语句 : 
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select * from products where P_name=' 达 利 元 '; 


查看 结果 ， 如 图 14.55 所 示 。 
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图 14.55 更 新 后 的 查询 列表 
从 图 14.55 可 以 看 出 ， 价 格 跟 生 产地 址 都 已 经 修改 成 功 。 
(5) 删除 名 为 “ 效 香 肠 ” 的 食品 ， 执 行 的 语句 如 下 : 
delete from products where P_name=' 效 香肠 ' ; 
在 执行 前 ， 用 语句 : 
select * from products where P_name=' 效 香肠 ' 7 
查询 下 当前 的 记录 ， 如 图 14.56 所 示 。 
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图 14.56 ”修改 前 的 结果 


执行 删除 语句 后 ， 运 行 结果 如 图 14.57 所 示 。 
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图 14.57 删除 操作 
从 图 14.57 中 可 以 看 出 ， 成 功 删除 1 条 语句 。 再 用 语句 : 


select * from products where P_name=' 桨 香肠 ' 7 


查看 结果 如 图 14.58 所 示 。 
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图 14.58 ”删除 后 的 查询 列表 
从 图 14.58 可 以 看 出 ， 表 中 已 经 没有 名 “ 纺 香 肠 ” 的 食品 数据 ， 数 据 量 为 0。 


实战 演练 2 一 一 数据 表 综 合 查询 案例 


上 节 介 绍 了 ， 记 录 表 的 增加 、 删 除 、 修 改 等 操作 。 本 节 回 顾 数据 表 的 另外 一 个 重要 的 知识 
数据 查询 。 本 节 带 读者 从 创建 表 开始 回顾 所 有 的 查询 知识 点 。 

这 里 以 表 14.4 和 表 14.5 的 表 结 构 在 org 库 中 创建 2 个 数据 表 dept〈 部 门 表 ) 和 emp (员工 
表 ) ， 按 照 表 14.6 和 14.7 所 示 增 加 数据 。 


表 14.4 dept 表 结构 





字段 名 数据 类 型 。 主键 
| deid |ina%) | 是 | 

下 
| address | vahalom | 否 | 否 
[apeode | ng | 二 | 万 


数据 类 型 E33 


| varchar20) | 否 
| varchar1) | 否 
| varchar (11) | 否 


decimal(8,2 
datetime 
int(10) 
varchar(100) 
varchar(20) 
varchar(50) 




















蕊 | 芯 





表 14.6 dept 表 数 据 

































dept_id dept_name address telephone 

2 调研 部 万 达 大 厦 2 楼 01088674563 
3 会 计 部 万 达 大 厦 3 楼 01088674564 
4 | 系统 集成 部 万 达 大 厦 4 楼 01088674565 
5 研发 部 万 达 大 厦 5 楼 01088674566 
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emp_id emp_name Sex mobile EElEIaN birth dept id address station remark 
加 a 
理 
ee ea 
理 
加 
监 
1005 主管 


1006 | 18902216671 | 1991-07- 高 级 工 
程 师 
1007 | 18902216671 a | 1983-06- 工程 师 


操作 过 程 如 下 : 
(1) 创建 表 dept 和 表 emp， 创 建 语句 分 别 如 下 : 











(2) 分 别 插入 数据 到 表 dept 和 表 emp 中 ， 插 入 语句 分 别 如 下 : 
插入 表 dept: 
INSERT into dept (dept id,dept name,address,zipcode,telephone) | 
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106 号 ',，' 主 管 '， 村 


VALUES (1， "销售 部 '， ' 万 达 大 厦 1 楼 '， 100000, 01088674562)， 
(2 ,' 调 研 部 ' ，' 万 达 大 厦 2 楼 ' ,100000， 01088674563)， 

(3，' 会 计 部 '"， ' 万 达 大 厦 3 楼 '， 100000, 01088674564)， 
(4，' 系统 集成 部 ' ， ' 万 达 大 厦 4 楼 '， 100000, 01088674565)， 
(5， "研发 部 '， ' 万 达 大 厦 5 楼 ' 1100000,01088674566); 


插入 表 emp: 


INSERT into emp (emp id, emp name, sex ,mobile,salary,birth 
raddress, station,remark) 

VALUES 
(L100L, "Mark'y m18902216671".8900 7%"1984=09=01"7 1 7 "成 寿 
' 销 售 经 理 '，' 销 售 经 理 ') ， 
(1002, 'Trump', 'm','18902216671',4567  ,，,'1989-08-01',1 


30 号 '，“' 业 务 员 '， ' 业 务 员 ')， 


rdept id 


ep 


1 ' 成 寿 寺 


(1003， 'Jone', 'f','18902216671',34562 ，'1967-09-21', 2 ，' 成 寿 寺 170 号 


' 副 总 经 理 ',' 副 总 经 理 ') ， 
(1004, 'Branks', ‘'m','"'18902216671',11000, '1989-01-01', 3 


103 号 '，' 财 务 总 监 '，' 财 务 总 监 ') ， 


(1005, 'Charles', 'f','18902216671',8876, '1990-10-11', 4 
> 
), 
(1006, 'James', 'm','18902216671',7899  ,'1991-07-05' ,5 





109 号 '，' 高 级 工程 师 '， ' 高 级 工程 师 ' ) ， 


1,' 成 寿 寺 
1,' 成 寿 寺 


,' 成 寿 寺 


(1007， 'Rose', 'f','18902216671',3790， '1983-06-06'， 5 ，' 成 寿 寺 10 号 '， 





' 工 程 师 '， "工程 师 ') ; 


(3) 查询 emp 表 中 ， 所 有 记录 的 emp_name、salary、emp_id 字段 值 。 其 语句 如 下 : 


Select emp name,emp id,salary from emp; 


执行 结果 如 图 14.59 所 示 。 
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图 14.59 执行 查询 结果 
(4) 查询 emp 表 中 ， 字 段 emp_id 等 于 1006 和 1007 的 所 有 记录 。 其 语句 如 下 : 
Select * from emp where emp id in(1006,1007) 7 


执行 结果 如 图 14.60 所 示 。 
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图 14.60 执行 查询 结 
(5) 查询 emp 表 中 ， 查 询 工资 范围 在 5000~10000 的 所 有 记录 。 其 语句 如 
select * from emp where salary between 5000 and 10000; 


执行 结果 如 图 14.61 所 示 。 
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984-99-81 68:88:98 1 


85 88:66:68 1 





图 14.61 执行 查询 结果 


(6) 查询 emp 表 中 ， 查 询 部 门 为 研发 部 所 有 员工 信息 。 其 语句 如 下 : 
Select * from emp where dept id=5; 
执行 结果 如 图 14.62 所 示 : 

图 wWsQLss Command Une Cent = 1 © le 








图 14.62 执行 查询 结果 


(7) 查询 emp 表 中 ， 每 个 部 门 工资 最 高 的 员工 信息 。 其 语句 如 下 : 


Select dept id,max (salary) from emp group by dept id” 
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执行 结果 如 图 14.63 所 示 。 





国 ws 








图 14.63 执行 查询 结果 
(8) 查询 emp 表 中 员工 Mark 的 基本 信息 。 其 语句 如 下 : 
select * from emp where emp name=’Mark’; 


执行 结果 如 图 14.64 所 示 。 





国 Wsa | 






4 + 成 寿 寺 1 | 理 





图 14.64 执行 查询 结果 


(9) 使 用 连接 查询 ， 查 询 所 有 员工 的 部 门 信息 。 其 语句 如 下 : 


select emp id,emp name,e.dept id,dept name from emp as e ,dept as d 
wherere:dept id =d,.dept id 


本 元 | 上 面 语句 中 用 as 


执行 结果 如 图 14.65 所 示 。 


而 = 


起 了 别名 。 




















图 14.65 ”执行 查询 结果 
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(10) 使 用 连接 查询 ， 查 询 每 个 部 门 的 员工 数 。 其 语句 如 下 : 


select d.dept name,count(*) from emp as e ,dept as d where e.dept id 
=d.dept id group by d.dept name 


执行 结果 如 图 14.66 所 示 。 











图 14.66 执行 查询 结果 
(11) 使 用 连接 查询 ， 查 询 每 个 部 门 的 总 工资 数 。 其 语句 如 下 : 


select d.dept name,sum(salary) from emp as e ,dept as d where 
e.dept id =d.dept id group by d.dept name 


执行 结果 如 图 14.67 所 示 。 
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图 14.67 执行 查询 结果 
(12) 使 用 连接 查询 ， 查 询 每 个 部 门 的 平均 工资 。 其 语句 如 下 : 


select d.dept name,avg(salary) from emp as e ,dept as dd where 
e.dept id =d.dept id group by d.dept name 


执行 结果 如 图 14.68 所 示 。 
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图 14.68 执行 查询 结果 
(13) 查询 工资 低 于 5000 的 员工 信息 。 其 语句 如 下 : 
select * from emp where salary < 5000; 


执行 结果 如 图 14.69 所 示 。 





国 wsa， 





6 pa:69:89 1 








图 14.69 执行 查询 结果 
(14) 查询 emp 表 ， 将 查询 记录 先 按 部 门 编号 由 低 到 高 排列 ， 再 按 工 资 由 高 到 低 排 列 。 其 语 
句 如 下 : 


select emp name,dept id,salary from emp order by dept id asc,salary 
desc; 


执行 结果 如 图 14.70 所 示 。 














图 14.70 执行 查询 结果 
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第 15 章 
< 数据 库 的 备份 和 还 原 > 


数据 库 中 的 数据 是 极其 重要 的 ， 作 为 数据 库 工程 师 会 想方设法 地 保全 数据 ， 但 是 意外 总 是 难 
免 ， 比 如 突然 间 的 断 电 、 网 络 中 断 、 操 作 人 员 的 失误 都 会 造成 数据 的 丢失 。 那 么 ， 定 期 备份 数据 
就 成 了 保证 数据 安全 的 最 重要 措施 之 一 。 当 出 现 数据 缺失 时 ， 还 原 原 先 备份 的 数据 ， 这 样 就 降低 
了 损失 。 各 种 数据 库 都 提供 了 多 种 数据 备份 与 还 原 的 方法 ，MySQL 也 不 例外 。 本 章 将 重点 介 经 
数据 备份 、 数 据 还 原 、 数 据 迁 移 和 数据 导入 导出 的 内 容 ， 真 正 让 读者 掌握 MySQL 数据 库 备份 。 





数据 备份 


当 系 统 意外 项 溃 或 者 网 络 中 断后 ， 数 据 库 工程 师 将 会 利用 备份 数据 对 表 进 行 恢复 ， 降 低 因 数 
据 库 的 宕 机 造成 的 损失 。MySQL 提供 了 以 下 2 种 方法 。 


15.1.1 使 用 命令 备份 


这 里 的 命令 是 mysqldump 命令 。 使 用 mysqldump 对 数据 库 进行 备份 ， 这 种 命令 方式 具有 普 
遍 性 ， 因 为 它 不 管 在 Linux 环境 还 是 Windows 环境 都 是 可 以 执行 的 。mysqldump 命令 执行 时 ， 
会 将 数据 库 中 的 数据 备份 成 一 个 文件 ， 其 实数 据 本 身 就 是 一 个 文件 。 

mysqldump 备份 数据 库 语句 的 形式 如 下 : 





mysqldump  -u user -h host -p password databasename[ 表 1，[ 表 2]] > 
XXXX .SGq1 


或 者 


MYSQLDUMP -u user -h host -p password databasename[ 表 1，[ 表 2]] > 
XXXX .SG1 

从 上 述 语 句 中 ， 可 以 看 出 “mysqldump ... ”或 者 “MYSQLDUMP...” 为 备份 的 关键 字 。 其 
中 user 表示 MySQL 用 户 名 ; host 表示 登录 MySQL 的 机 器 ; 本 机 可 以 用 localhost 代替 ; 
password 是 登录 MySQL 数据 库 密码 ，databasename 是 需要 备份 的 数据 库 名 称 ; xxxx.sql 为 备份 





























的 文件 名 称 。 下 面 分 别 讲述 mysqldump 备份 的 3 种 场景 : 备份 单个 数据 库 中 的 所 有 表 、 备 份 音 
个 库 中 的 指定 表 、 备 份 多 个 数据 库 。 


1. 使 用 mysqldump 备份 数据 库 中 的 所 有 表 
【示例 15-1】 使 用 mysqldump 命令 备份 数据 库 中 的 所 有 表 。 我 们 以 第 13 章 中 的 数据 库 为 


会 











图 15.1 打开 命令 窗口 


(2) 输入 备份 命令 : 


mysqldump —uroot -hlocalhost -P3306 = org 
>d:\backup\orgdb 20161115.sql 


输入 密码 之 后 ，MySQL 就 会 对 数据 库 进 行 备份 ， 在 di\backup 文件 夹 就 会 新 增 一 个 
orgdb 20161115.sql 文件 。 











副 元 在 MySQL 5.6 之 后 ， 直 接 输入 备份 命令 ， 可 能 会 报 如 图 152 所 示 错 误 ， 这 是 由 于 需要 在 | 
【 MySQL 的 安装 路 径 下 执行 备份 命令 。 
国 管理 员 : C\Windows\system32\cmd.exe | 


“SET OPTION SQL_QUO 
k the nanual th 


"OPTION S 





读者 可 以 打开 orgdb 20161115.sql 备份 文件 ， 并 用 文本 编辑 器 打开 查看 其 内 容 : 
-- MySQL dump 10.13 Distrib 5.6.15, for Win64 (x86 64) 


== Host: iocalhost Database: org 


-- Server version 5.6.15-log 
/*!40101 SET GOLD CHARACTER SET CLIENT=@@CHARACTER SET CLIENT */; 


/*!40101 SET @OLD CHARACTER SET RESULTS=@@CHARACTER SET RESULTS */; 
/*!40101 SET Q@OLD COLLATION CONNECTION=@@COLLATION CONNECTION */; 
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从 文件 中 可 以 看 出 ， 备 份 文件 中 包含 了 数据 库 名 、 主 机 信息 、MySQL 版 本 号 、 创 建 表 的 语 
句 、 赋 值 系统 变量 等 内 容 。 备 份 文件 中 还 有 “SET” 语 句 ， 这 些 语句 的 作用 是 将 系统 变量 赋值 给 
当前 用 户 定义 变量 ， 该 SET 语句 将 当前 系统 变量 的 值 赋值 给 当前 用 户 定义 变量 ， 例 如 : 


备份 文件 的 最 后 几 行 是 恢复 服务 器 系统 变量 的 值 ， 例 如 : 
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从 备份 文件 中 可 以 看 出 ，MySQL 数据 库 是 以 “--” 注 释 ，“/*! xx */;” 这 种 内 容 是 MySQL 
可 以 执行 的 注释 方式 。 在 其 注释 内 容 中 有 数字 ， 这 些 数 字 表 示 ， 语 句 只 有 在 指定 的 MySQL 版 本 
或 者 较 高 版 本 的 情况 下 才能 被 执行 。 例 如 40101， 表 示 只 有 在 MySQL 版 本 号 为 4.1.1 或 者 更 高 
的 版 本 下 才 可 以 被 执行 。 

2. 使 用 mysqldump 备份 数据 库 中 的 指定 表 

使 用 mysqldump 备份 数据 库 中 的 指定 表 ， 其 语法 形式 跟 备份 所 有 表 的 语法 形式 基本 一 致 ， 
区 别 在 于 备份 指定 表 要 在 数据 库 后 面 加 表 名 。 


【示例 15-2】 使 用 mysqldump 命令 备份 org 数据 库 中 的 dept 表 。 执 行 语句 如 下 : 


执行 完 语句 ， 会 在 D:\backup\ 下 创建 dept_20161115.sql 的 备份 文件 与 orgdb_20161115.sql 文 
件 不 同 的 是 ， 文 件 中 还 包含 dept 表 的 插入 值 语句 。dept_20161115.sql 的 内 容 如 下 : 
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) ENGINE=InnoDB AUTO INCREMENT=6 DEFAULT CHARSET=utf8; 
/*!40101 SET character set client = Qsaved cs client */; 


-- Dumping data for table ‘dept. 


LOCK TABLES ‘dept WRITE; 
/*!40000 ALTER TABLE ‘dept’ DISABLE KEYS */; 


INSERT INTO 


“dept” VALUES (1,， 销售 部 万达 大 


厦 1 楼 
',100000, 1088674562), (2, ' 调 研 部 '，,' 万 达 大 厦 2 楼 ', 100000,1088674563)， Co 


1! 万达 大 厦 3 楼 ',100000,1088674564), (4," 系统 集成 部 …' 万达 


1 100000,1088674565) , (5, ' 研 发 部 ',' 万 达 大 厦 5 楼 ' , 100000,1088674566); 
/*!140000 ALTER TABLE ‘dept. ENABLE KEYS */; 
UNLOCK TABLES; 
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/*!40103 


/*!40101 
/*!40014 
/*!40014 
/*!140101 
/*!140101 
/*!40101 
/*!140111 


SET 


SET 
SET 
SET 
SET 
SET 
SET 
SET 


TIME ZONE=@OLD TIME ZONE */; 


SQL MODE=@OLD SQL MODE */; 

FOREIGN KEY CHECKS=@OLD FOREIGN KEY CHECKS */; 
UNIQUE CHECKS=@OLD UNIQUE CHECKS */; 

CHARACTER SET CLIENT=@OLD CHARACTER SET CLIENT */; 
CHARACTER SET RESULTS=@OLD CHARACTER SET RESULTS */; 
COLLATION CONNECTION=@OLD COLLATION CONNECTION */; 
SQL NOTES=@OLD SQL NOTES */; 


-- Dump completed on 2016-11-15 16:13:54 
导出 单 张 表 时 ， 
@ ”没有 给 用 户 权 限 ， 那 么 可 以 赋予 : 


GRANT ALL PRIVILEGES ON *.* TO ‘root'@'%'IDENTIFIED BY ‘root' WITH 
GRANT OPTION 


权限 。 


可 能 会 发 生 如 图 15.3 所 示 的 错误 。 那 么 可 能 造成 的 原因 是 : 


与 值 之 间 有 空格 。 





图 15.3 备份 错误 


3. 使 用 mysqldump 备份 多 个 数据 库 
使 用 mysqldump 备份 多 个 数据 库 ， 其 基本 形式 如 下 : 
mysqldump -uuser -hhost -p -databases dbl] [db2..] >db.sqgl 


从 上 述 语句 中 ， 
第 14 章 中 的 org 库 跟 test 为 例 。 


可 以 看 出 增加 了 参数 databases， 多 个 数据 库 之 间 用 空格 隔 开 。 我 们 以 备份 
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【示例 15-3】 使 用 mysqldump 命令 备份 org 数据 库 和 test 数据 库 。 执 行 语句 如 下 : 
mysqldump -uroot -p -databases org test > d:\backup\org test 20161115.sql 


执行 效果 如 图 15.4 所 示 。 





国信 理 R: CAWindows\system32\emd exe [一 > 一 | 








图 154 备份 多 个 数据 库 
执行 后 会 在 dvbackup\ 目 录 下 面 新 增 一 个 org test_ 20161115.sql 文件 ， 里 面包 含 了 创建 2 个 库 
所 需 的 语句 跟 数据 。 这 里 文件 太 长 ， 就 不 列 出 来 。 
mysqldump 命令 后 面 的 参数 其 实 还 有 很 多 ， 表 15.1 只 列 出 部 分 内 容 ， 更 多 的 应 该 去 官网 
(http://downloads.mysql.com/) 查找 。 


表 15.1 mysqldump 命令 参数 








参数 说 明 

这 个 选项 代表 激活 了 Mysqldump 命 令 的 quick、add-drop-table、add-locks、extended- 

i lock-tables 参 数 ， 也 就 是 通过 - opt 参 数 在 使 用 Mysqldump 导 出 MySQL 数 据 库 信息 
时 不 需要 再 附加 上 述 这 些 参数 

在 每 个 创建 create database 语 句 前 添加 drop database 

在 每 个 创建 create table 语 句 前 添加 drop table 

用 LOCK TABLES 和 UNLOCK TABLES 语 句 引 用 每 个 表 转 储 ， 重 载 转 储 文件 时 插入 得 

--add-locking 更 快 

库 中 所 有 的 表 

参数 值 有 0 或 1， 默 认 是 1， 包 含 程序 版 本 、 服 务 器 版 本 和 主机 ;如 果 是 0， 则 不 包含 这 
些 内 容 

减少 输出 内 容 ， 减 少 注释 的 输出 

备份 成 与 旧版 的 MySQL 更 兼容 的 输出 ， 其 值 可 以 是 db2、maxdb、ansi、mysql40、 

postgresql、oracle 等 















--compatible 




















--complete-insert，-c_| 使 用 包含 列 名 的 完整 DNSERT 语 句 
--delete，-D 导入 文件 前 清空 表 
















--debug 写 调 试 日 志 
一 default-character-set | 备份 使 用 默认 字符 集 
备份 前 刷新 数据 库 日 志文 件 
暴力 备份 ， 错 误 仍 继续 备份 
bles，-x _ | 对 所 有 数据 库 中 的 所 有 表 加 锁 
ock-tables, 备份 前 锁定 所 有 的 表 


没有 创建 数据 库 语句 
--no-create-info，-t 只 是 备份 表 数 据 ， 没 有 创建 表 
只 是 备份 表 结 构 ， 不 备份 表 数 据 
~-DasSwWord,-p MySQL 数 据 库 的 连接 密码 

一 Version，-V 显示 版 本 信息 并 退出 


卫 
-xml,， -XX 以 XML 文 件 输 出 
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15.1.2 ”使 用 第 3 方 工具 快速 备份 


现 如 今 MySQL 数据 库 的 客户 端 多 种 多 样 ， 例 如 自身 的 MySQL Workbench、navicat 等 ， 它 
们 都 能 快速 、 便 捷 地 备份 数据 库 。 下 面 以 MySQL Workbench 工具 为 例 讲述 如 何 备份 。 


(1) 打开 MySQL Workbench 工具 ， 如 图 15.5 所 示 。 





国 wsat wortbmd 











图 15.5 MySQL Workbench 工具 


(2) 连接 数据 库 ， 如 图 15.6 所 示 。 





国 Wo wotbereh 


ea 
加 。 到， me geey Det swwer es srtptog aly 


EG BEEG Ts 








| 


© ODEO 








图 15.6 连接 数据 库 


(3) 单 击 左 侧 边栏 的 Data Export 选项 ， 选 择 需要 备份 的 数据 库 ， 


15.7 所 示 。 
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单 击 Start Export， 如 图 
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15.7 ”导出 数据 库 


执行 成 功 后 ， 会 在 指定 目录 生成 文件 夹 ， 文 件 夹 中 包含 了 库 中 所 有 的 表 SQL 文件 ， 如 图 
15.8 所 示 。 








GO Ha, sD) ,becep ， dmpillallsagi 








| 
让 必要 汪 Sa 
及 下 本 Lera beokeeql 
天 站 DD erg depteal 
轴 二 it 人 要 目 
erg produeazq 
油库 | 目 =ereeee 
习 Subversion sy 
] test tu teechersql 
[hea test student clesssal 
[ed test studentLsql 
旧闻 test teachersql 
EE | test usersq 
中 
FE 
sql 和 可 日 丈 2015/11/15 1943 。。 当主 日 坊 2016/11/15 9v43 
A 323 KB 























15.8 生成 后 sql 文件 


1 5 .2 数据 还 原 


有 数据 备份 就 有 数据 还 原 ， 还 原 一 般 是 在 数据 丢失 或 者 数据 库 宕 机 时 进行 的 操作 。 通 过 对 数 
据 的 还 原 可 以 快速 地 还 原 至 丢失 前 的 数据 库 ， 最 大 限度 减少 损失 以 及 最 大 限度 地 保持 数据 完整 
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性 。MySQL 数据 提供 了 以 下 方法 。 


15.2.1 使 用 命令 还 原 
这 里 的 命令 是 MySQL 或 者 source 命令 。 对 于 已 经 备份 的 SQL 文件 ， 可 以 使 用 MySQL 命 
令 导 入 到 数据 库 中 ， 这 要 与 备份 的 命令 区 分 开 。 
1. 使 用 MySQL 命令 还 原 数 据 库 
从 上 节 可 以 得 知 备份 中 的 文件 是 包含 了 create、insert 语句 。MySQL 命令 可 以 直接 执行 文件 
中 的 语句 。 其 形式 如 下 : 
mysql -uuser -p db<dbname.sql 
上 述 语 法 中 user 是 数据 库 的 用 户 名 ; -p 表示 输入 数据 库 的 密码 ，db 是 数据 库 名 称 ， 是 可 选 
项 ， 如 果 备 份 中 的 文件 包含 创建 数据 库 语句 ， 那 么 还 原 时 可 不 指定 数据 库 名 ， 如 果 没 有 ， 则 需要 
指定 数据 库 名 称 ， 和 否则 会 报错 。 下 面 以 例子 说 明 如 何 使 用 MySQL 命令 导入 。 
【示例 15-4】 使 用 MySQL 命令 将 例 15.1 中 的 备份 文件 di\backup\ orgdb 20161115.sql 文件 导 
入 到 数据 库 中 。 
执行 过 程 如 下 : 
(1) 打开 命令 窗口 ， 如 图 15.1 所 示 。 
(2) 输入 还 原 命令 : 


mysql -uroot -p org < d:\backup\ orgdb 20161115.sql 





二 执行 上 述 语句 前 确保 MySQL 中 存在 org 数据 库 ， 否 则 导入 时 会 出 错 。 | 





命令 执行 成 功 后 orgdb 20161115.sql 文件 中 的 数据 就 会 被 导入 到 数据 库 中 ， 其 结果 如 图 15.9 
所 示 。 





eel 

















图 15.9 MySQL 导入 后 的 列表 


source 命令 还 原 数据 库 ， 其 形式 也 很 简单 ， 下 面 介绍 下 它 的 使 用 方法 ， 但 是 执行 它 的 前 提 是 
已 经 登录 到 数据 库 中 ， 且 待 还 原 的 数据 库 已 经 创建 完毕 。 
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2. 使 用 source 命令 还 原 数据 库 
用 source 命令 导入 SQL 文件 ， 其 语法 如 下 : 
source filename 
【示例 15-5】 使 用 source 命令 将 di\backup\ orgdb 20161115.sql 文件 导入 到 数据 库 中 。 
执行 过 程 如 下 : 


(1) 打开 命令 窗口 ， 如 图 15.1 所 示 。 
(2) 使 用 root 用 户 登 录 服 务 器 ， 如 图 15.10 所 示 。 





园 wysQl s6 Command line Client 


二 || 








图 15.10 登录 MySQL 服务 器 
(3) 输入 语句 “use org”。 
(4) 执行 语句 : 
source d:\backup\orgdb 20161115.sql 


其 结果 如 图 15.11 所 示 。 





国 Mysal /rE | 














图 15.11 执行 导入 结果 





剖 执行 source 命令 时 ， 要 先 选 择 数据 库 ， 否 则 会 报 如 图 15.12 错误 。 
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团 MySQL 56 Command Line Client 











图 15.12 错误 截图 


15.2.2 ”使 用 工具 快速 还 原 
使 用 工具 还 原 数 据 库 ， 这 里 同样 以 MySQL Workbench 工具 为 例 讲 述 如 何 还 原 。 


(1) 打开 MySQL Workbench 工具 ， 如 图 15.5 所 示 。 

(2) 连接 数据 库 ， 如 图 15.6 所 示 。 

(3) 单 击 左 侧 边 栏 的 Data Import/Restore 选项 ， 选 择 已 经 备份 的 文件 夹 或 者 文件 ， 单 击 
Start Import， 如 图 15.13 所 示 。 




















图 15.13 导入 数据 库 
执行 完 ， 数 据 库 中 的 数据 就 还 原 到 备份 时 的 数据 。 


数据 库 迁 移 


何 为 数据 库 迁 移 ? 为 什么 要 数据 库 迁 移 ? 数据 库 迁 移 可 以 理解 为 数据 的 备份 或 者 数据 库 的 升 
级 又 或 者 数据 库 的 数据 转移 。 下 面 介绍 3 种 场景 的 数据 库 迁 移 : 相同 版 本 的 MySQL 数据 库 迁 
移 、 不 同 版 本 的 MySQL 数据 库 迁 移 、MySQL 数据 库 迁 移 至 Oracle 数据 库 。 
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15.3.1 ”相同 版 本 的 MySQL 数据库 迁 移 


相同 版 本 的 MySQL 数据 库 的 迁移 ， 这 种 方式 迁移 比较 简单 ， 直 接 可 以 理解 为 将 数据 库 先 备 
份 再 还 原 。 那 么 通用 的 方法 就 是 先 用 mysqldump 命令 导出 数据 库 或 者 数据 ， 然 后 使 用 mysql 命 
令 或 者 source 命令 导入 整个 库 或 者 数据 到 目标 库 中 。 下 面 以 一 个 例子 来 说 明 。 


【示例 15-6】 将 172.0.0.X 主机 上 的 MySQL 数据 库 全 部 迁移 到 172.0.1.X 主机 上 。 
执行 过 程 如 下 : 

(1) 在 172.0.0.X 主机 上 打开 命令 窗口 ， 如 图 15.1 所 示 。 

(2) 在 172.0.0.X 主机 上 ， 执 行 命令 : 


mysqldump -h 172.0.0.X -uroot -ppassword -all-databases 


(3) 在 172.0.1.X 主机 上 打开 命令 窗口 ， 如 图 15.1 所 示 。 
(4) 执行 命令 : 


mysql -h 172.0.1.X -uroot -ppassword 
如 此 ， 就 完成 了 相同 版 本 的 MySQL 数据 库 迁 移 ， 十 分 简单 、 快 捷 。 


15.3.2 ”不同 版 本 的 MySQL 数据 库 之 间 的 迁移 


不 同 版 本 的 MySQL 数据 库 之 间 的 迁移 ， 会 涉及 新 旧版 本 的 情况 ， 如 果 是 旧版 本 升级 为 新 版 
本 ， 那 么 更 新 比较 简单 ， 也 是 可 以 理解 为 将 数据 库 先 备份 再 还 原 ， 那 么 迁移 过 程 如 同 相 同 版 本 的 
迁移 。 

如 果 是 新 版 本 降级 为 旧版 本 ， 这 种 情况 就 要 特殊 处 理 SQL 语句 ， 一 般 情况 低 版 本 不 兼容 高 
版 本 ， 比 如 字符 集 、 数 据 类 型 等 。 特 别 是 有 中 文 的 数据 ， 需 要 特别 注意 ， 可 能 出 现 无 法 正常 显示 
的 情况 。 


15.3.3 MySQL 数据 库 迁 移 至 Oracle 数据 库 


Oracle 数据 库 和 MySQL 数据 库 都 是 当今 十 分 流行 的 数据 库 ， 有 很 多 厂商 选择 它们 ， 因 为 它 
们 之 间 的 转换 相对 比较 便捷 ， 并 且 它们 SQL 语句 遵守 的 标准 都 是 SQL92 标准 ， 理 解 起 来 也 方 
便 。 

在 数据 迁移 之 前 ， 需 要 比较 两 个 数据 库 之 间 的 差异 ， 因 为 不 同 的 库 之 间 相 同类 型 的 关键 字 可 
能 会 不 一 样 。 例 如 ，MySQL 中 字符 串 是 varchar， 而 oracle 中 使 用 varchar2; MySQL 中 日 期 字段 
有 TIME 和 DATE， 而 ORACLE 日 期 字段 有 date 和 timestamp。 在 处 理 好 数据 类 型 之 后 。 就 可 以 
直接 将 导出 的 MySQL 语句 在 Oracle 中 执行 ， 或 者 将 Oracle 语句 在 MySQL 中 执行 。 
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表 的 IMPORT 和 EXPORT 


前 面 章 节 介绍 了 数据 库 的 备份 ， 相 信 大 家 对 库 的 简单 备份 有 了 初步 了 解 。 那 么 当 只 是 想 备份 


库 中 的 某 张 表 或 者 只 是 恢复 某 张 表 的 数据 ， 该 如 何 操作 ? 本 章 将 对 单 张 表 或 者 多 张 表 的 导入 导出 
做 个 介绍 。 本 节 将 详细 介绍 导出 导入 的 几 种 方法 ， 其 中 导出 的 方法 有 SELECT ...INTO 
OUTFILE、mysqldump 命令 导出 、mysql 命令 导出 ; 导入 的 方法 有 mysqlimport 导入 、LOAD 
DATA INFILE 导入 。 先 来 介绍 下 导出 的 方法 。 


15. 


4.1 表 的 EXPORT 

对 于 表 的 导出 有 多 种 方法 ， 这 里 只 介绍 常用 的 3 种 方法 。 

1. 用 SELECT...INTO OUTFILE 导出 文本 文件 

使 用 select..… into outfile 导出 文本 文件 ， 其 语法 形式 如 下 : 

SELECT columnlist from table where condition INTO OUTFILE 'filename' 


FIELDS TERMINATED BY ‘VALUE' 

FIELDS [OPTIONALLY] ENCLOSED BY 'value' 
FIELDS ESCAPED BY 'value' 

LINES STARTING BY 'value' 

LINES TEARMINATED BY '‘'value'] 


从 上 述 语法 中 可 以 看 出 SELECT columnlist from table where condition 为 查询 语句 ，into 


outfile 是 将 查询 结果 返回 到 指定 文件 中 。 后 面 的 参数 是 可 选项 ， 其 参数 值 参见 表 15.2 所 示 。 













参数 
FIELDS TERMINATED BY 'VALUE' 


FIELDS [OPTIONALLY] ENCLOSED BY value' 


FIELDS ESCAPED BY value' 





表 15.2 ”select... into outfile 参 数 说 明 





设置 子 段 之 间 的 分 割 字符 ， 默 认 分 割 字符 是 “\ 
设置 字段 的 包围 字符 ， 只 能 为 单个 字符 ， 如 果 使 用 了 
OPTIONALLY， 则 只 有 CHAR 和 VARCHAR 等 字段 数 
据 被 包括 
设置 转 义 字符 ， 只 能 为 单个 字符 ， 默 认 值 为 “\ 











LINES STARTING BY "value' 设置 每 行 数据 开头 的 字符 ， 默 认 情况 下 不 使 用 任何 字符 ， 






可 以 为 单个 或 多 个 字符 





LINES TEARMINATED BY value' 设置 每 行 结尾 的 字符 ， 默 认 值 为 “nm”， 可 以 为 单个 或 多 






性 元 | FIELDS 和 LINES 都 是 自选 的 ， 但 是 如 果 两 个 都 被 指定 了 ，FIELDS 必须 位 于 LINES 前 。 


个 字符 
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【示例 15-7】 使 用 SELECT...INTO OUTFILE 将 org 数据 库 中 的 dept 表 中 的 记录 导出 到 文件 。 
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执行 过 程 如 下 : 


(1) 打开 命令 窗口 ， 如 图 15.1 所 示 。 
(2) 使 用 root 用 户 登 录 服务 器 ， 如 图 15.10 所 示 。 
(3) 执行 命令 如 下 : 


~ Select * from org.dept INTO OUTFILE "D:/backup/dept.txt” 
执行 完 语句 后 ， 进 入 目录 “D:/backup/” 用 UE 工具 查看 dept.txt 文件 ， 其 文件 内 容 如 下 





如 果 用 记事 本 打开 文件 ， 可 能 就 是 一 整 行 的 数据 ， 这 是 因为 Windows 系统 下 回 车 换行 为 
“wn”， 所 以 所 有 的 记录 会 在 同一 行 显示 。 


【示例 15-8】 使 用 SELECT...INTO OUTFILE 将 org 数据 库 中 的 products 表 中 的 产品 名 称 、 
生产 商 、 生 产地 址 、 备 注 的 记录 导出 到 文件 ， 使 用 FIELDS 选项 和 LINES 选项 ， 要 求 字 段 之 间 
使 用 分 号 “; ”分 割 ， 所 有 字段 值 用 单 引号 括 起 来 ， 定 义 转 义 字符 为 双 引 号 “\"”， 执 行 
命令 如 下 : 





该 语句 把 products 表 中 pname,productors,prod address ，remark 记录 导入 到 
D:/backup/dept2.txt 文本 文件 中 。FIELDS TERMINATED BY “表示 字段 之 间 用 分 号 分 隔 ; 
ENCLOSED BY "表示 每 个 字段 用 单 引号 括 起 来 : ESCAPED BY """ 表 示 系 统 默 认 的 转 义 字符 
替换 为 双 引 号 ，LINES TERMINATED BY rm' 表 示 每 行 以 回 车 换行 符 结尾 ， 保 证 每 条 一 行 记 
录 。 命 令 执行 成 功 后 ， 进 入 目录 “D:/backup/”, 用 UE 工具 查看 dept2.txt 文件 ， 其 文件 
内 容 如 下 : 





从 上 文 可 以 看 出 ， 所 有 的 字段 值 都 被 单 引号 包括 ; 空 值 的 表示 形式 为 “"N”， 即 使 用 双 引 
号 蔡 换 了 反 和 斜 线 转 义 字符 。 
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【示例 15-9】 使 用 SELECT...INTO OUTFILE 将 org 数据 库 中 的 products 表 中 的 产品 名 称 、 
生产 商 、 生 产地 址 、 备 注 的 记录 导出 到 文件 ， 使 用 LINES 选项 ， 要 求 每 行 以 字符 串 “>> ”开始 ， 
以 “>>end>>” 字 符 串 结尾 ， 执 行 的 命令 如 下 : 


命令 执行 成 功 后 ， 进 入 目录 “D:/backup/” 用 UE 工具 查看 dept3.txt 文件 ， 其 文件 内 容 


| 
四 


从 内 容 上 可 以 看 出 ， 所 有 的 字段 值 都 导出 到 dept3.txt 中 ， 但 是 记录 没有 分 行 显示 ， 出 现 这 种 
情况 是 因为 TERMINATED BY 中 没有 添加 转 义 的 换行 符 “rn”， 修 改 后 的 语句 如 下 : 





执行 完 语句 之 后 ， 进 入 目录 “D:/backup/” 用 UE 工具 查看 dept4.txt 文件 ， 其 文件 内 容 如 





从 内 容 中 可 以 看 出 ， 分 行 显示 查询 出 的 记录 。 


select...into outfile 方法 导出 文件 ， 需 注意 导出 的 文件 不 能 是 已 有 的 文件 ， 否 则 会 报 文件 已 
经 存在 的 错误 ， 无 法 读 写 的 错误 。 





2. 用 mysqldump 命令 导出 文本 文件 


mysqldump 命令 不 仅 能 将 数据 库 导 出 ， 也 可 以 将 数据 库 导 出 为 纯 文本 文件 。Mysqldump 导 
出 文本 文件 的 基本 语法 格式 如 下 : 
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在 上 述 语法 中 ，-T 代表 指定 了 导出 的 是 纯 文本 文件 ，path 表示 导出 数据 的 路 径 ， tables 指定 
要 导出 的 表 名 称 ， 若 省 略 表示 导出 数据 库 中 所 有 的 表 ; 后 面 的 参数 详 见 表 15.3 所 示 。 


表 15.3 mysqldump 导出 文本 文件 参数 说 明 
参数 说 明 


设置 字段 之 问 的 分 割 字符 ， 默 认 是 “\t” 
| fiadsenclosedbyvalue | 设置 有 息 的 包围 9 答 | 


—fields-enclosed-by=value 设置 字段 的 包围 字符 


~fields-optionally-enclosed-by=value 设置 字段 的 包围 字符 ， 只 能 为 单个 字符 ， 只 能 包括 
CHARHEVARCHAR 等 


设置 转 义 字符 ,默认 值 为 反 斜 线 “” 
设置 每 行 数据 结尾 的 字符 ， 默 认 值 为 “mn” 


【示例 15-10】 使 用 mysqldump 将 org 数据 库 中 的 products 表 中 的 记录 导出 到 文件 ， 执 行 的 
命令 如 下 : 


命令 执行 成 功 后 ， 进 入 目录 “D:/backup/”， 用 UE 工具 查看 dept3.txt 文件 ， 其 文件 内 
容 如 下 : 


画 mysqldump 在 Windows 命令 行 中 执行 。 


语句 执行 成 功 后 ， 在 D:/backup 目录 下 面 会 有 两 个 文件 ， 分 别 为 products.sql 和 products.txt。 
products.sql 文件 中 有 products 表 的 CREATE 语句 ， 其 内 容 如 下 : 
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products.txt 中 的 内 容 为 : 





两 个 文件 内 容 完全 不 一 样 ，products.sql 包含 创建 表 跟 插入 表 数据 的 语句 ，products.txt 中 只 
是 数据 的 文本 文件 。 


【示例 15-11】 使 用 mysqldump 将 org 数据 库 中 的 products 表 中 的 产品 名 称 、 生 产 商 、 生 产 
地 址 、 备 注 等 的 记录 导出 到 文件 ， 使 用 FIELDS 选项 ， 要 求 字段 之 间 使 用 分 号 “;” 间 隔 ， 所 有 
字符 类 型 字段 值 用 单 引 号 括 起 来 ， 定 义 转 义 字符 为 “#”， 每 行 记录 以 回 车 换行 符 “\n” 结 尾 ， 
执行 的 命令 如 下 : 


语句 执行 成 功 后 ，D:/backup/ 目 录 下 也 会 有 两 个 文件 ， 分 别 为 products.sql 和 products.txt。 
products.sql 中 跟 例子 示例 15-10 中 的 products.sql 一 样 ，products.txt 文件 的 内 容 如 下 : 
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2; ' 山楂 片 '; ' 胖 胖 山 植 ';54.67; "2016-10-10'7; "沈阳 胖 胖 ;235; "沈阳 胖 胖 ， 
3; "酒鬼 花生 ' ; ' 四 川 酒鬼 ' ;4 .56; '2016-11-01';' 四 川 酒鬼 ' ;158; ' 四川 酒 鬼 ' 
4; ' 香瓜 瓜子 ' ; ' 治 治 食 品 ' ;5.56; '2016-08-15'; ' 福 建 治 治 ' ;230; "福建 洽 洽 ' 
5; ' 蓉 花子 '; ' 治 治 食 品 ' ;1.56; '2016-11-13';' 福 建 治 治 ';300; ' 福 建 治 洽 ' 
6; ' 花 生 油 '; ' 鲁 花花 生 ' ;78.68; '2016-10-09';#N;40;'' 


从 内 容 上 可 以 看 到 ， 只 有 字符 类 型 的 值 被 单 引 号 括 了 起 来 ， 数 值 类 型 的 值 没有 ; NULL 值 表 


示 为 “#N”， 使 用 “#” 蔡 代 了 系统 默认 的 反 和 斜 线 转 义 字符 作 


3. 用 MySQL 命令 导出 文本 文件 


除了 mysqldump 命令 导出 外 ， 还 可 以 用 MySQL 命令 导出 。MySQL 命令 也 是 在 命令 行 模 式 
下 执行 SQL 指令 ， 将 查询 结果 导入 到 文本 文件 中 。 使 用 MySQL 导出 数据 文件 的 基本 语法 如 下 : 


mysql -uroot -p --execute="select 语句 " database > filename.txt 


在 上 面 的 语法 中 ，--execute 代表 要 执行 的 语句 ， 具 体 的 查询 语句 用 双 引 号 括 起 来 ， 执 行 完 语 


句 后 退出 ，database 代表 要 导出 的 数据 库 名 称 ，filename.txt 表示 导出 的 文件 名 。 


【示例 15-12】 使 用 MySQL 语句 将 org 数据 库 中 的 products 表 中 的 记录 导出 到 文件 ， 执 行 


语句 如 图 15.14 所 示 : 





而 管理 员 : C\Windows\system32\cmd.exe ll 





图 15.14 MySQL 导出 命令 


语句 执行 成 功 后 ，D:/backup/ 目 录 下 也 会 有 mysql_products.txt。mysql_products.txt 文件 的 内 


容 如 下 : 


P idp name productors price Prod date remark kc num prod address 
1 大 利 元 福建 达 利 \t ”27.58 ”2016-11-10 福建 达 利 食品 200 福建 泉州 达 利 元 
2 山楂 片 ” 胖 胖 山 植 54.67 2016-10-10 沈阳 胖 胖 235 沈阳 胖 胖 

3 ”酒鬼 花生 四 川 酒鬼 4.56 ”2016-11-01 四 川 酒鬼 158 四 川 酒鬼 

4 ”香瓜 瓜子 洽 洽 食品 5.56 ”2016-08-15 福建 洽 洽 230 福建 治 洽 

5 葵花子” 洽 洽 食品 1.56 ”2016-11-13 福建 洽 洽 300 福建 治 洽 

6 ， 花生油” 鲁 花花 生 78.68 2016-10-09 NULL 40 


从 内 容 上 可 以 看 出 ， 第 1 行 包含 了 各 个 字段 的 名 称 ， 从 第 2 行 开始 分 行 显示 数据 ， 列 之 间 用 


空格 隔 开 ， 如 果 内 容 中 有 空格 则 以 “\t” 转 义 表示 ， 例 如 第 2 行 福建 达 利 产品 。 读 者 能 发 现 
MySQL 导出 的 文本 文件 可 读 性 更 强 。 


当 数 据 表 的 字段 太 多 ， 可 以 加 参数 “--vertical ”来 指定 查询 结果 的 显示 格式 。 


【示例 15-13】 使 用 MySQL 语句 将 org 数据 库 中 的 products 表 中 的 记录 导出 到 文件 ， 使 用 参 
“--vertical ”执行 语句 如 下 : 


271 





PHP+MySQL 网 站 开发 从 零 开始 学 〈 视 频 教学 版 ) 】 


语句 执行 成 功 后 ，D:/backup/ 目 录 下 也 会 有 mysql_products2.txt。mysql_products2.txt 文件 的 
内 容 如 下 : 
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从 内 容 中 可 以 看 出 ， 其 显示 格式 发 生 了 变化 ， 当 然 这 种 方式 仅 限于 字段 太 长 的 情况 ， 因 为 这 
样 更 加 便于 查看 。 





MySQL 导出 文本 文件 只 能 是 在 命令 行 中 进行 且 MySQL 服务 要 启动 。 








15.4.2” 表 的 IMPORT 


表 的 导入 也 是 有 多 种 方法 ， 可 以 使 用 第 3 方 工具 ， 也 可 以 使 用 命令 ， 当 然 这 里 主要 是 讲解 命 
令 的 导入 方式 ， 工 具 的 导入 实质 就 是 根据 命令 做 的 可 视 化 操作 。 


1. 用 LOAD DATAINFILE 方式 导入 文本 文件 
LOAD DATA INFILE 语句 的 基本 格式 如 下 : 





从 语法 中 可 以 看 出 ，filename.txt 为 导入 数据 的 源 文件 ，TABLENAME 为 导入 的 表 名 。 后 面 
的 参数 都 是 可 选项 ， 具 体 的 请 参见 表 15.4。 


表 15.4 LOAD DATA INFILE 参 数 说 阴 









参数 说 明 


设置 字段 之 间 的 分 割 字符 ， 默 认 分 割 字符 是 “ 


or Wt OW om wrt 


OPTIONALLY， 则 只 有 CHAR 和 VARCHAR 等 字段 数 


据 被 包括 


设置 转 义 字符 ， 只 能 为 单个 字符 ， 默 认 值 为 人 
LINES TEARMINATED BY value 














设置 每 行 数据 开头 的 字符 ， 默 认 情况 下 不 使 用 任何 字 
符 ， 可 以 为 单个 或 多 个 字符 
设置 每 行 结尾 的 字符 ， 默 认 值 为 “mn，， 可 以 为 单个 或 多 
个 字符 


从 表 15.4 中 可 以 看 出 参数 的 含义 与 SELECT ... INTO OUTFILE 中 参数 的 定义 是 一 样 的 。 下 
面 我 们 就 将 SELECT .… INTO OUTFILE 导出 的 文件 用 LOAD DATA INFILE 导入 。 
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【示例 15-14】 使 用 LOAD DATA INFILE 命令 将 di\backup\depttxt 中 的 数据 导入 到 org 数据 
库 中 的 dept 表 中 。 
执行 过 程 如 下 : 
(1) 打开 命令 窗口 ， 如 图 15.1 所 示 。 
(2) 使 用 root 用 户 登 录 服务 器 ， 如 图 15.10 所 示 。 
(3) 分 别 执行 以 下 命令 : 


use org; 
delete from dept; 


执行 完 后 ， 表 dept 中 的 数据 就 为 0 条 数据 ， 如 图 15.15 所 示 。 





国 MysQL 56 Command Line Cient [oo © es 





图 15.15 ”删除 数据 的 结果 


(4) 执行 导入 语句 如 下 : 
LOAD DATA INFILE 'd:/backup/dept .txt' INTO TABLE org.dept; 
执行 完 语句 ， 其 结果 如 图 15.16 所 示 。 


国 MysQL 56 Command Line Clent [EX 一 | 


DATA INFILE ’d:/backup/dept.txt’ INIO TABLE org.depts 


ovs affected 《<B-B1 sec) 
5 Deleted: 9 Skipped: 8 Varnings: 日 





图 15.16 执行 还 原 
(5) 语句 执行 成 功 后， 用 命令 : 
Select * from dept; 


查看 表 中 的 数据 ， 如 图 15.17 所 示 。 








园 MySQL 5.6 Command Line client 





图 15.17 导入 dept 表 后 的 数据 列表 
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从 图 15.17 中 可 以 看 出 ， 数 据 已 经 恢复 到 dept 表 中 。 


上 一 个 例子 介绍 了 LOAD DATA INFILE 命令 的 基本 使 用 方法 ， 下 个 例子 介绍 添加 参数 时 该 
如 何 使 用 。 


【示例 15-15】 使 用 LOAD DATA INFILE 命令 将 di\backup\products.txt 中 的 数据 导入 到 org 
数据 库 中 的 products 表 中 ， 使 用 FIELDS 选项 和 LINES 参数 ， 要 求 字段 之 间 使 用 分 号 “;” 间 
隔 ， 所 有 字段 值 用 单 引号 括 起 来 ， 定 义 转 义 字符 为 “#”。 

执行 过 程 如 下 : 

(1) 打开 命令 窗口 ， 如 图 15.1 所 示 。 

(2) 使 用 root 用 户 登 录 服 务 器 ， 如 图 15.10 所 示 。 

(3) 分 别 执行 以 下 命令 : 

use org; 

delete from dept; 

执行 完 后 ， 表 dept 中 的 数据 就 为 0 条 数据 ， 如 图 15.15 所 示 。 

(4) 执行 导入 命令 如 下 : 


LOAD DATA INFILE 'd:/backup/ products.txt' INTO TABLE org 
FIELDS TERMINATED BY ';" 
ENCLOSED BY '\'' 
ESCAPED BY "#" 
LINES TERMINATED BY '\r\n'; 


.Products 


执行 成 功 后 ， 其 结果 如 图 15.18 所 示 。 





国 wysaL s6com 














图 15.18 执行 导入 语句 
(5) 语句 执行 成 功 后 ， 用 命令 : 
Select * from products; 


查看 表 中 的 数据 ， 如 图 15.19 所 示 。 
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18-89 ;NULL 














图 15.19 导入 products 表 后 的 数据 列表 


营 寺 | LOAD DATA INFILE 命令 用 何 种 方式 或 者 添加 什么 参数 ， 取 决 于 导入 源 数据 的 txt 中 的 格式 | 


是 什么 样 的 。 例 如 ， 例 子 中 depttxt 为 简单 的 导出 文件 ， 以 “Ww &， 那 么 用 添加 参数 
| 的 导入 语句 就 会 导入 失败 ， 如 图 15.20 所 示 。 















8 MySQ. 5.6 Commanc Line Cliert ll 


pt .txt’ INIO TABLE org.dept 


cts .txt， INIO TABLE org 





图 15.20 导入 不 对 应 的 数据 文件 


从 上 面 的 例子 可 以 看 出 表 的 LOAD DATA INFILE 导入 命令 与 SELECT…INTO OUTFILE 导 
出 命令 是 相对 应 的 ， 用 哪 种 参数 方式 导出 就 用 哪 种 参数 导入 ， 否 则 就 会 报错 。 


2. 用 mysqlimport 命令 导入 文本 文件 


除了 用 LOAD DATA INFILE 方式 导入 文本 文件 外 ， 还 可 以 使 用 mysqlimport 导入 。 
mysqlimpoort 导入 的 语法 如 下 : 


mysqlimport -uroot -p dbname filename .txt[ 
--fields-terminated-by=value 
--fields-enclosed-by=value 
--fields-optionally-enclosed-by=value 
--fields-escaped-by=value 
--lines-terminated-by=value 
--ignore-lines=n 


] 


从 语法 上 看 ， 跟 LOAD DATA INFILE 有 很 多 相似 的 关键 字 。dbname 为 数据 库 名 称 。 参 数 说 
明 详 见 表 15.5 所 示 。 
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表 15.5 mysqlimport 参数 说 明 






—fields-terminated-by=value 设置 字段 之 间 的 分 割 字符 ， 默 认 是 “\t” 
—fields-enclosed-by=value 设置 字段 的 包围 字符 
~fields-optionally-enclosed-by=value 设置 字段 的 包围 字符 ， 只 能 为 单个 字符 ， 只 能 包括 
CHARHEVARCHAR 等 
—fields-escaped-by=value 设置 转 义 字符 ， 默 认 值 为 反 斜 线 “\t” 
—lines-terminated-by=value 设置 每 行 数据 结尾 的 字符 ， 默 认 值 为 “\n” 
忽略 数据 文件 的 前 n 行 
【示例 15-16】 使 用 mysqlimport 命令 将 di:\backup\products.txt 中 的 数据 导入 到 org 数据 库 中 
的 products 表 中 ， 字 段 之 间 使 用 分 号 “;” 间 隔 ， 所 有 字段 值 用 单 引号 括 起 来 ， 定 义 转 义 字符 为 
“#”， 每 行 记录 以 回 车 换行 符 “\n” 结 束 。 
执行 过 程 如 下 : 
(1) 打开 命令 窗口 ， 如 图 15.1 所 示 。 
(2) 执行 的 命令 如 下 : 
mysqlimport -uroot -p org d:/backup/products.txt--fields-terminated- 


by=; --fields-optionally-enclosed-by=\' --fields-escaped-by=# --lines- 
terminated-by=\r\n 


执行 效果 如 图 15.21 所 示 。 


国信 理 员 CAWindews\system32\emd.exe [S15 me 






























--ignore-lines=n 

















图 1521 mysqlimport 导入 效果 
从 图 15.21 可 以 得 出 ，mysqlimport 执行 时 需要 几 个 注意 事项 : 
@ mysqlimport 命令 没有 指明 表 名 ， 表 名 是 由 导入 的 文件 名 决定 ， 如 果 表 名 不 存在 ， 则 导 
入 失败 。 
®@ mysqlimport 导入 命令 在 Windows 命令 窗口 中 执行 。 
@ ”命令 中 添加 参数 ， 那 么 导入 的 文件 中 需要 有 规定 的 字符 ， 否 则 会 导入 失败 ， 要 对 应 起 来 。 
(3) 语句 执行 成 功 后 ， 用 命令 : 
Select * from products; 


查看 表 中 的 数据 ， 如 图 15.22 所 示 。 
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5-11-13 1 


10-89 ! NULL 














图 15.22 mysqlimport 导入 products 表 后 的 数据 列表 


实战 演练 一 一 数据 库 的 备份 与 恢复 


在 实际 项 目 中 ， 数 据 库 的 备份 是 极其 重要 的 ， 作 为 数据 库 工程 师 ， 应 该 定期 地 备份 数据 库 ， 
养 成 良好 的 习惯 。 这 样 即使 因 系统 出 现 故 障 、 数 据 丢 失 也 能 将 损失 减 到 最 少 。 本 节 的 综合 案例 将 
介绍 数据 库 的 备份 与 还 原 。 

操作 过 程 如 下 : 

(1) 使 用 mysqldump 命令 将 books 表 备 份 到 文件 D:\backup\books_bak.sql。 
打开 命令 窗口 ， 输 入 命令 如 下 : 

mysqldump -uroot -p org books >d:\backup\books bak.sql 


执行 过 程 如 图 15.23 所 示 。 











图 15.23 mysqldump 备份 books 表 
语句 执行 成 功 后 ， 在 D:/backup 目录 下 面 会 有 个 books_bak.sql 文件 ， 用 UE 工具 打开 其 内 容 
如 下 : 
-- MySQL dump 10.13 Distrib 5.6.15, for Win64 (x86 64) 
-- Host: localhost Database: org 


-- Server version 5.6.15-log 
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/*!40111 SET SQL NOTES=@OLD SQL NOTES */; 
=- Dump completed on 2016-11-19 19:50:39 
(2) 使 用 MySQL 命令 还 原 books 表 到 org 数据 库 中 。 


在 用 命令 还 原 books 表 数 据 前 ， 先 清空 books 中 所 有 的 记录 ， 输 入 SQL 语句 如 图 15.24 所 示 。 





国 MySQL 5.6 Command Line Client | 器 








图 15.24 执行 删除 命令 
在 MySQL 命令 行 输入 还 原 语句 如 下 : 
source d:\backup\books bak.sql 
语句 执行 成 功 后 ， 使 用 SQL 语句 : 
select * from books; 


查看 表 books 中 的 数据 ， 如 图 15.25 所 示 。 


国 MSsQL 56 Command Une Client = ln 











图 15.25 mysql 命令 导入 表 books 列表 


从 图 中 可 以 看 出 ， 还 原 表 books 成 功 。 

(3) 使 用 SELECT ... INTO OUTFILE 语句 导出 books 表 中 的 记录 ， 导 出 文件 位 于 目录 
Di\backup 下 ， 名 称 为 books.txt。 

语句 执行 命令 如 图 15.26 所 示 。 


国 mwsQtsscommardtnecient [ER 
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图 15.26 SELECT ... INTO OUTFILE 导出 命令 
语句 执行 成 功 后， 在 D:/backup 目录 下 面 会 有 个 books.txt 文件 ， 用 UE 工具 打开 其 内 容 如 下 : 


>>'1';'oracle 数据 库 大 全 ' ; ' 谭 伟 *';'77.15'>>end>> 
>>'2';"'mysql 数据 库 大 全 ' ; ' 谭 * 强 '; '69.55'>>end>> 
>>'3';'java 笔记 大 全 ' ; ' 徐 * 浩 ';'97.45'>>end>> 
>>'4';'WEB 开发 大 全 ' ; ' 林 伟 *';'87.00'>>end>> 
>>'5';'tomcat 服务 器 说 明 '; ' 张 **';'27.00'>>end>> 
>>'6';'html 开发 说 明 ' ; ' 赵 * 强 ';'45.00'>>end>> 
>>'7';"'css3 开 发 说 明 ' ; ' 谢 **';'67.45'>>end>> 
>>'8';'jquery 手册 大 全 ' ; ' 周 **';'68.00'>>end>> 
>>'9';'oracle 高 级 编程 ';' J**';'57.44'>>end>> 
>>'29';'css3+js 开发 说 明 ' ; ' 谢 **';'67.45'>>end>> 
>>'30';'extJS 手册 大 全 ' ; ' 周 **';'68.35'>>end>> 
>>'31';'oracle 优化 ';' J]**';'57.44'>>end>> 
>>'32';'spark';' 肖 **';'77.45'>>end>> 


从 内 容 上 得 知 ， 命 令 是 不 同 字 段 之 间 使 用 分 号 阳 开 ; 字段 值 使 用 单 引号 包含 ， 每 行 记录 以 
“>>” 开 始 ; 每 行 记录 以 “>>end>>” 和 回 车 换行 符 结 束 。 











(4) 使 用 LOAD DATA INFILE 语句 导入 books.txt 数据 到 books 表 中 。 
同样 ， 在 导入 数据 前 ， 先 登录 数据 库 将 表 books 中 的 数据 全 部 删除 ， 如 图 15.27 所 示 。 


国 MySQL 5.6 Command Une Cient [= 














图 15.27 执行 删除 命令 
输入 导入 语句 如 下 : 
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LOAD DATA INFILE 'D:/backup/books.txt' INTO TABLE org.books 
FIELDS TERMINATED BY ';' 
ENCLOSED BY '\'' 
ESCAPED BY "\"" 
LINES STARTING BY '>>' TERMINATED BY '>>end>>\r\n'; 


语句 执行 之 后 ，books.txt 中 的 数据 就 导入 到 books 表 中 。 记 得 导入 时 命令 要 加 上 books.txt 中 
的 特殊 字符 ， 这 样 才 可 以 导入 成 功 且 确保 数据 的 正确 性 。 

使 用 SQL 语句 : 

select * from books; 

查看 表 books 中 的 数据 ， 如 图 15.28 所 示 。 


画 wsatssc: yl >| 














图 15.28 mysql 命令 导入 表 books 列表 
从 图 中 可 以 看 出 ， 还 原 表 books 成 功 。 


(5) 使 用 MySQL 命令 将 books 表 中 的 记录 导出 到 文件 D:\backup\books.xml。 
导出 表 数 据 到 xml 文件 ， 使 用 MySQL 命令 时 需要 指定 --xml 参数 选项 。 在 Windows 命令 窗 
口 输入 命令 如 下 : 


mySsql =uroot ‘<p ==xml ==execute="select * from books, ™ org > 
d:\backup\books.xml 


语句 执行 成 功 后 ， 在 D:/backup 目录 下 面 会 有 个 books.xml 文件 ， 用 UE 工具 打开 其 内 容 如 下 : 


<?xm] version="1.0"?> 
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以 上 只 列 出 部 分 books.xml 内 容 。 可 能 有 中 文 的 会 显示 乱码 ， 那 么 需要 导出 的 时 候 加 上 默认 
编码 字符 参数 “--default-character-set=name”， 编 码 值 为 表 中 的 字符 编码 ， 如 此 就 能 正确 显示 。 
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前 面 我 们 已 经 知道 了 MySQL 的 基本 操作 ， 那 如 何 建立 起 PHP 与 MySQL 的 连接 呢 ? 要 在 
PHP 中 使 用 MySQL， 我 们 需要 了 解 PHP 都 提供 了 哪些 与 之 相关 的 函数 ， 以 及 这 些 函数 怎么 用 。 
本 章 的 目的 就 是 让 读者 学 会 如 何在 PHP 中 操作 MySQL 数据 库 。 


启动 XAMPP 中 自 带 的 MySQL 数据 库 


通过 查看 XAMPP 的 控制 面板 ， 我 们 会 看 到 “MySQL” 这 一 项 ， 如 图 16.1 所 示 。 根 据 这 个 
面板 ， 我 们 来 说 说 MySQL 的 图 形 化 操作 。 








回 xAMpp Control Panél 3.22 [Compiled: Nov 12th 2015] 上 | 忆 

XAMPP Control Panel v3.2.2 coro 
NModules | 
Service Module PID(s) Port(s) ”Actions tt | | 


3828 
Apache 2344 80,443 Admn Confg || Logs Ca 
CE ] Eco ets) nme 





FieZila Start Config || Logs | Services 
Mercury start Eco Ce] [ Gep | 
Tomcat Start Config |[ Logs | Tr" 
] [main] XANPP Installation Directory: “c:\xampp\” 
3 [main] Checking for prerequisites 
[main] All prerequisites found 
[nain] Initializing NModules 
[main] Starting Check-Timer 
[main] Control Panel Ready 


[Apache] Attempting to start Apache app... 
[Apache] Status change detected: rurming 











图 16.1 XAMPP 的 控制 面板 


16.1.1 启动 MySQL 





在 XAMPP 中 启动 MySQL 服务 非常 简单 ， 单 击 其 后 的 Start 按钮 即 可 。 要 操作 这 个 数据 
库 ， 我 们 可 以 单 击 图 16.1 右 侧 的 Shell 按钮 ， 进 入 DOS 界面 ， 如 图 16.2 所 示 。 


第 16 章 PHP 操作 MySQL 


画 YAMPP for Windows 





etting environment for using XAMPP for Windows. 
imal@TIMA1-PC c:\xamnpp 











图 162 DOS 界面 
进入 DOS 界面 后 ， 我 们 需要 使 用 命令 进入 数据 库 ，XAMPP 初始 化 的 root 密码 是 空 ， 所 以 
可 以 不 用 输入 密码 直接 进入 。 
输入 : 


mysql -uroot 
正确 打开 MySQL 的 界面 如 图 16.3 所 示 。 








Setting environnent for using XAMPP for Windows. 
inal@TIMA1-PC c:\xanpp 

mysql -uroot 

elcome to the MariaDB monitor- Comnands end with ; or \g- 
our MariaDB connection id is 3 
Server version: 19.1.16-MariaDB nariadb.org binary distribution 


opyright 《c》 2888, 2816,. Oracle, MariaDB Corporation Ab and ot 


ype ’help;’ or ’\h’ for help. Type ’\e’ to clear the current i 





riaDB [Cnone>]> 


163 启动 MySQL 


16.1.2 ”使 用 phpMyAdmin 图 形 化 操作 MySQL 

上 面 是 用 命令 行 的 方式 启动 MySQL， 我 们 没有 进行 任何 操作 ， 这 里 我 们 通过 图 形 化 的 方式 
来 操作 MySQL。 

(1) 在 浏览 器 中 输入 http://127.0.0.1， 进 入 XAMPP 的 界面 ， 如 图 16.4 所 示 。 


一 El 
加 Welcome x \ 国 windows 7 x Fess x 
| < © BD 127.0.0.1/dashboard/ 至 立 三 | 
2 哺 互联 网 职业 技能 - -… 资源 汇总 | 数 模 » 









Apache Friends 


XAMPP 


Apache + MariaDB + PHP + Perl 








图 16.4 XAMPP 的 界面 
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二 图 16.4 放大 的 时 候 没有 这 个 MENU 菜单 ， 会 直接 显示 图 165 的 这 几 个 菜单 项 。 | 














(2) 单 击 右 上 角 的 MENU， 会 出 现 如 图 16.5 所 示 的 菜单 。 


Apache Friends 


Applications 


FAQs 

HOW-TO Guides 
PHPInfo 
phpMyAdmin 





16.5 MENU 菜单 


(3) 选择 pppMyAdmin 会 打开 它 的 主 界面 。 如 果 这 3 步 已 经 熟悉 了 ， 可 直接 在 浏览 器 中 输 
入 http:/127.0.0.1/phpmyadmin/ 进 入 如 图 16.6 所 示 的 phpMyAdmin 主 界面 。 























站 一 一 一 一 一 Pa [EYE 
省 127.0.01 /127.0.0.1 | pl x WN x 
€ CC 0 EU 六 | 王 | 
洪 应 用 二 互 联网 职业 技能 - .。。 训 资 源 世 总 | 致 锰 ” 哺 去 津 党- 网 时 去 课堂 门 ] APP 工 具 门 APP 运 营 门 新 尘 汪 门 技 本 二 客 | 
phpMyAdmin 国 - 
pl 
会 是 窜 9 | 
近期 访问 表 收 藏 | 
股 有 最 近 使 用 的 才 匿 | 
一 已 新 妈 | 
es 国 。 服务 关连 接 排序 规则 局: 。 服务 器 : 127.0.0. 1 via 
由 -3 infomatian_schema TCM 了 | 
由 nyeal wfomb4_unicode ci 。 服务 器 类 型 ， JriaB | 
轩 _ perfornance_schena 。 服务 器 版 本 : 10.1. 16-MariaDB| 
- mariadb. ore binary 
书 - phpnyadnin 让 stribution 
tost | 外 观 设置 协议 版 本 : 10 
，。 用 户 : root@ocalhost | 
各 语言 - Lngvare @: 。 服务 器 字符 集 ; UTF-8 Unicode| 
一 (utf8) i 
中 文 - Chinese simplified | 
| 
砚 主题 : pmahomme | 
=。 字号: | 82% » 各 ache/2.4.23 (Win32) | 
0 .0.2h PHP/T.0.9 
更 多 设置 版 本 : 1ibnysql 
- Wsqlnd 5.0.12-dev — 
20150407 - $Id: 是 
241ae00989d1995ff cbbf63d579%4 
加 控制 台 > 











图 166 phpMyAdmin 主 界面 
(4) 此 时 ， 我 们 可 以 通过 左 侧 的 “新 建 ” 菜 单 来 创建 MySQL 数据 库 。 具 体 如 何 创建 


数据 库 ， 我 们 在 学 习 MySQL 的 时 候 已 经 都 了 解 过 了 ， 这 里 只 简单 说 明 这 个 打 
phpMyAdmin 的 步骤 。 
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1〗6 .2 pHp 连接 和 关闭 数据 库 


在 用 户 和 Web 应 用 系统 的 交互 过 程 中 ，PHP 对 数据 库 的 操作 是 连接 整个 系统 前 后 端的 纽 
带 。 本 节 将 介绍 PHP 如 何 连接 MySQL 数据 库 ， 以 及 如 何 关闭 连接 。 


16.2.1 连接 数据 库 


PHP 通过 MySQL 提供 的 API 与 MySQL 连接 。MySQL 提供 了 两 种 用 于 连接 数据 库 服务 器 
的 方法 : 


@ mysqlit MySQL 增强 版 扩展 。 
@ ”PDO MYSQL: 提供 了 一 个 Abstraction Layer (抽象 层 ) 来 操作 数据 库 ， 这 样 ， 无 论 使 
用 什么 数据 库 ， 都 可 以 通过 一 致 的 函数 执行 查询 和 获取 数据 。 


PDO 在 使 用 时 需要 先 通过 php.ini 开启 ， 而 mysqli 的 使 用 对 入 门 者 来 说 稍微 简单 ， 本 章 我 们 
就 主讲 mysqli。mysqli 的 结构 如 下 : 


其 中 各 参数 的 意义 如 下 : 


@ host: 服务 器 名 ， 一 般 为 localhost。 
usemame: 登录 用 户 名 。 

passwd: 登录 密码 。 

dbname: 数据 库 名 。 

port: 端口 号 。 


【示例 16-1】 连 接 数 据 库 。 








从 代码 中 可 以 看 出 ，mysqli 是 面向 对 象 型 的 写法 ， 这 里 读者 要 注意 。 


287 


PHP+MySQL 网 站 开发 从 零 开始 学 〈 视 频 教学 版 ) 





16.2.2 ”关闭 数据 库 


前 面 的 示例 中 我 们 已 经 使 用 了 $mysqli->close0)， 这 是 mysqli 关闭 数据 库 连 接 的 写法 ， 其 语 
法 如 下 : 


boolmysqli::close (void) 
它 的 作用 就 是 关闭 之 前 打开 的 连接 。 成 功 时 返回 rue， 或 者 在 失败 时 返回 false。 


16.3 phHp 操作 数据 库 


上 一 节 介绍 了 如 何 连 接 与 关闭 数据 库 ， 这 一 节 来 介绍 连接 到 MySQL 服务 后 ， 如 何 对 数据 库 
进行 显示 可 用 数据 库 、 创 建新 的 数据 库 、 选 择 数 据 库 以 及 删除 数据 库 等 常见 的 数据 库 操作 。 


16.3.1 显示 可 用 数据 库 


在 对 数据 库 进行 操作 之 前 ， 先 查看 MySQL 服务 器 上 的 数据 库 信息 是 很 有 必要 的 ， 其 中 就 需 
要 获取 可 用 数据 库 的 数量 。 在 查看 可 用 数据 库 信息 时 ， 需 要 使 用 到 以 下 几 个 方法 : 


该 方法 对 指定 的 连接 对 象 执行 一 次 查询 ， 其 中 各 参数 的 意义 如 下 : 


@ $query 为 指定 的 SQL 语句 。 

S$resultmode 为 存储 模式 。 

执行 query() 方 法 返回 一 个 结果 集 对 象 。 而 要 显示 数据 库 信息 需要 执行 的 SQL 语句 为 : 
SHOW DATABASES. 


且 SQL 语句 对 大 小 写 不 敏感 ， 所 以 SHOW DATABASES 等 同 于 show databases。 


除 此 之 外 还 需要 用 到 结果 集 对 象 的 获取 结果 集 数量 的 方法 : 








该 方法 不 需要 任何 参数 ， 执 行 即 可 获取 结果 集 数 。 
另外 ， 还 需要 用 到 结果 集 的 fetch_row 方法， 该 方法 以 键 值 对 数组 形式 返回 每 条 结果 的 内 
容 : 
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同样 该 方法 也 不 需要 参数 ， 用 户 可 以 通过 遍历 调用 该 方法 以 获取 结果 集 对 象 的 所 有 内 容 。 
【示例 16-2】 显 示 可 用 数据 库 。 





执行 以 上 代码 ， 其 结果 如 图 16.7 所 示 。 


CY @ apyizooislp - OX 0 
CE 


该 服务 器 上 共有 4 个 数据 库 ， 分 别 是 ， 
information_schema 

mysql 

performance_schema 

test 





图 16.7 显示 可 用 数据 库 


根据 用 户 服务 器 中 数据 库 内 容 的 不 同 ， 所 显示 的 内 容 也 会 有 所 差别 ， 但 都 可 以 显示 出 数据 库 
的 信息 。 


16.3.2 ”创建 数据 库 


有 时 需要 在 服务 器 上 创建 一 个 新 的 数据 库 供 程序 使 用 ， 其 方法 也 为 使 用 mysqli 对 象 的 
query() 方 法 执行 创建 数据 库 语 句 : CREATE DATABASE， 在 该 语句 后 面 跟 上 需要 创建 的 数据 库 
名 称 即 可 。 


【示例 16-3】 创 建新 的 数据 库 。 
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以 上 代码 先 执行 获取 所 有 数据 库 的 查询 ， 然 后 创建 新 库 ， 最 后 再 执行 获取 所 有 数据 库 的 查 
询 ， 以 比较 创建 新 库 前 后 的 不 同 。 执 行 以 上 代码 ， 其 结果 如 图 16.8 所 示 。 


后 E Cd 
Clr 
该 服务 器 上 共有 4 个 数据 库 ， 分 别 是 ， 


information_schema 
mysql 


performance_schema 


test 

该 服务 器 上 共有 5 个 数据 库 ， 分 别 是 ， 
information_schena 

my_db 

mysql 

performance_schema 

test 





图 16.8 创建 新 的 数据 库 


16.3.3 ”选择 数据 库 


如 果 在 初始 化 mysqli 对 象 时 没有 指定 需要 操作 的 数据 库 ， 可 以 使 用 mysqli 对 象 的 select_db() 
方法 来 选择 数据 库 ， 该 方法 如 下 : 


pool mysqli::select db ( string $dbname ) 
其 中 参数 $Sdbname 即 为 需要 选择 的 数据 库 的 名 称 。 


本 方法 应 该 只 被 用 在 改变 本 次 链接 的 数据 库 ， 用 户 也 可 以 在 mysqli_connectO 时 指定 第 四 个 
参数 确认 默认 数据 库 。 
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16.3.4 ”删除 数据 库 


与 创建 数据 库 相 对 应 的 就 是 删除 数据 库 ， 如 果 一 个 数据 库 已 经 不 再 需要 ， 出 于 安全 与 节省 服 
务 器 空间 的 考虑 可 以 将 其 删除 ， 使 用 mysqli 对 象 的 query0 方 法 执行 删除 数据 库 语句 : DROP 
DATABASE， 在 该 语句 后 面 跟 上 需要 删除 的 数据 库 名 称 即 可 。 


【示例 16-4】 删 除数 据 库 。 





以 上 代码 先 执行 获取 所 有 数据 库 的 查询 ， 然 后 删除 数据 库 my_db， 最 后 再 执行 获取 所 有 数 
据 库 的 查询 ， 以 比较 删除 前 后 的 不 同 。 执 行 以 上 代码 ， 其 结果 如 图 16.9 所 示 。 


由 -|G htpyiz7ooiisip - OX Dr 0 
br 


该 服务 器 上 共有 5 个 数据 库 ， 分 别 是 ， 


information_schema 


performance_schema 


test 

该 服务 器 上 共有 4 个 数据 库 ， 分 别 是 ， 
information_schema 

mysqal 

performance_schema 

test 





16.9 ”删除 数据 库 
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16.4 pHp 操作 数据 表 


相对 于 数据 库 ， 数 据 表 的 使 用 就 更 为 广泛 ， 常 见 的 操作 包括 : 新 建 一 个 表 ， 并 为 表 指定 各 字 
段 内 容 、 属 性 ; 编辑 已 经 存在 的 表 的 各 项 设 定 以 及 删除 已 经 存在 的 表 等 。 本 节 来 介绍 这 些 内 容 。 


16.4.1 ”查看 所 有 数据 表 


连接 上 服务 器 ， 并 选择 指定 的 数据 库 之 后 ， 可 以 通过 mysqli 对 象 的 query() 方 法 执行 SQL 语 
句 : SHOW TABLES 来 查看 当前 库 中 所 有 的 数据 表 。 


【示例 16-5】 显 示 所 有 数据 表 。 





执行 以 上 代码 ， 其 结果 如 图 16.10 所 示 。 


DB YG npyizooasap - BO Xn 
[Bw «| | 


数据 库 test 中 共有 0 个 数据 表 ， 分 别 是 ， 





图 16.10 显示 所 有 数据 表 
由 于 当前 库 中 并 没有 任何 表 ， 所 以 显示 结果 数 为 0。 
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16.4.2 ”新 增 数据 表 


在 指定 的 数据 库 中 新 增 数据 表 ， 也 是 使 用 mysqli 对 象 的 query() 方 法 执行 建 表 的 SQL 语句 : 
CREATE TABLE 来 实现 ， 其 语法 格式 如 下 : 


其 中 除了 指定 表 的 名 称 之 外 ， 还 需要 指定 每 个 字段 的 名 称 及 类 型 。 下 面 的 例子 说 明了 如 何 创 
建 一 个 新 的 数据 表 。 


【示例 16-6】 新 增 数据 表 。 





执行 以 上 代码 ， 其 结果 如 图 16.11 所 示 。 


| 四 -|@ hpyzooansip - OX Dr 0 
[2 


成 功 创建 表 : MyClass 


数据 库 test 中 共有 1 个 数据 表 ， 分 别 是 ， 


myclass 





16.11 创建 数据 表 
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16.4.3 ”查看 数据 表 字 段 


在 为 数据 表 添 加 内 容 之 前 ， 需 要 事先 知道 数据 表 每 个 字段 的 情况 ， 这 时 可 以 通过 mysqli 对 
象 的 query() 方 法 执行 SQL 语句 : DESC table name， 进 行 查看 ， 其 中 的 table_name 为 需要 查看 
的 表 的 名 称 。 


【示例 16-7】 查 看 数据 表 结构 。 





执行 以 上 代码 ， 其 结果 如 图 16.12 所 示 。 


®t tpn20nsnp - Ox 0 
[eww x | 


几 数据 表 myclass 中 共有 4 个 字段 ， 分 别 是 ， 


痕 比 : id 字段 类 型 ，int (4) 


字段 名 称 ，degree a int (4) 





图 16.12 查看 数据 表 所 有 字段 


16.4.4 ”编辑 数据 表 


数据 表 在 创建 之 后 并 不 是 一 成 不 变 的 ， 有 时 需要 对 表 的 内 容 比如 表 中 字段 的 名 称 或 者 属性 等 
进行 修改 。 通 过 mysqli 对 象 的 query0 方 法 执行 SQL 语句 : ALTER TABLE 进行 修改 ， 该 语句 不 
但 可 以 修改 表 中 已 经 有 的 内 容 ， 还 可 以 为 表 增 加 或 者 删除 字段 。 根 据 其 使 用 方法 不 同 ， 关 键 字 也 
不 同 ， 其 中 添加 字段 的 语句 语法 如 下 所 示 。 
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其 中 table name 为 需要 执行 添加 字段 的 表 的 名 称 ，column_name 为 添加 的 字段 名 称 ， 而 
datatype 为 字段 类 型 。 
删除 表 中 指定 的 列 ， 使 用 以 下 语句 : 


以 添加 类 似 ，table_name 为 需要 执行 删除 字段 的 表 的 名 称 ，column_name 为 删除 的 字段 名 
称 。 
修改 某 一 个 已 经 存在 的 列 ， 使 用 以 下 语句 : 


其 中 table name 为 需要 执行 修改 字段 的 表 的 名 称 ，column_name 为 修改 的 字段 名 称 ， 而 
datatype 为 字段 类 型 。 

在 实际 使 用 时 ， 一 定 要 注意 每 种 不 同 操作 所 对 应 SQL 语句 的 关键 字 。 

下 面 的 示例 演示 了 将 myclass 表 中 的 degree 字段 删除 ， 添 加 名 为 : birthday 的 字段 ， 还 将 sex 
字段 的 类 型 改 为 字符 型 。 


【示例 16-8】 编 辑 数据 表 。 





执行 以 上 代码 其 结果 如 图 16.13 所 示 。 
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Cr 


字 隐 名 称 birthday 字段 类 型 ，int (4) 





图 16.13 编辑 数据 表 


对 比 图 16.12 与 图 16.13 的 结果 可 以 看 到 原来 的 字段 : degree 被 删除 ， 添 加 了 名 为 : birthday 
的 字段 ， 而 且 原 有 字段 sex 的 类 型 也 被 成 功 改变 。 


16.4.5 ”删除 数据 表 


如 果 一 个 数据 表 不 再 需要 ， 可 以 通过 SQL 语句 DROP TABLE 将 其 删除 ， 在 该 语句 后 面 跟 上 
需要 删除 的 数据 表 名 称 即 可 。 


【示例 16-9】 删 除数 据 表 。 





16.5 pHp 操作 数据 


使 用 数据 库 归 根 结 底 还 是 要 使 用 表 中 的 数据 ， 可 以 说 数据 才 是 核心 。 这 一 节 来 介绍 如 何 使 用 
PHP 来 操作 MySQL 表 中 的 数据 。 常 见 的 数据 操作 有 : 新 增 数据 、 编 辑 数据 、 删 除数 据 以 及 查询 
数据 等 。 


16.5.1 ”新 增 数据 
一 个 数据 表 被 建立 之 后 ， 里 面 空空 如 也 ， 要 根据 需要 向 其 中 添加 数据 内 容 。 使 用 mysqli 对 
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象 的 query() 方 法 ， 执 行 SQL 语句 INSERT INTO， 就 可 以 将 指定 的 内 容 插入 数据 表 中 。 该 语句 使 
用 方法 如 下 : 
INSERT INTO table name ( 列 1, 列 2,...) VALUES ( 值 , 值 2,....) 


其 中 的 列 1、 列 2 为 需要 添加 的 字段 名 称 ， 值 1、 值 2 为 字段 所 对 应 的 内 容 。 
下 面 通过 一 个 示例 来 演示 如 何 使 用 INSERT INTO 语句 将 指定 数据 内 容 添加 到 数据 表 中 。 


【示例 16-10】 添 加 数据 。 





执行 以 上 代码 ， 其 结果 如 图 16.14 所 示 。 


四 .|@ npyiooyiwp ~ OX 于 广 vO 
[ee | 





16.14 ”向 表 中 添加 数据 


a 在 向 表 中 新 增 数据 时 ， 所 指定 的 字段 名 称 必 须 正确 ， 而 且 所 添加 的 内 容 也 要 与 该 字段 类 型 一 





致 ， 否 则 就 会 出 现 错误 。 | 


16.5.2 ”查看 数据 


如 果 要 查看 数据 表 中 的 所 有 数据 或 者 某 一 条 数据 ， 可 以 通过 mysqli 对 象 的 query() 方 法 执行 
SQL 语句 :SELECT 来 实现 ， 该 语句 的 语法 格式 如 下 所 示 。 


SETECT 列 名 称 FROM 表 名 称 
其 中 的 列 名 称 即 为 想 要 查看 的 某 列 字段 名 ， 表 名 称 为 需要 查看 的 表 的 名 称 。 如 果 想 要 查看 所 
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有 字段 可 以 使 用 : 
SETIECT * FROM 表 名 称 


以 上 两 个 语句 都 将 返回 表 的 所 有 数据 ， 如 果 想 要 查看 特定 数据 ， 可 以 在 SELECT 中 使 用 
WHERE 子 句 : 


SELECT 列 名 称 FROM 表 名 称 WHERE 列 运算 符 值 
其 中 的 运算 符 内 容 如 表 16.1 所 示 。 
表 16.1 WHERE 子 句 中 的 运算 符 类 型 


操作 符 








其 中 最 常用 到 就 是 “=” 操 作 符 。 
下 面 的 示例 演示 了 如 何 使 用 SELECT 语句 配合 WHERE 子 句 查看 数据 表 中 的 特定 数据 。 


【示例 16-11】 查 看 数据 。 





执行 以 上 代码 ， 其 结果 如 图 16.15 所 示 。 
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| EE 
| @ pnzanonsnp- OX 0 
[Er 


共 搜 索 到 1 条 数据 
Array ( [0] => 1 [id] => 1 [1] => Mike [name] => Mike 
[2] => 男 [sex] = 男 [3] => 1990 [birthday] => 1990 ) 









图 16.15 查看 数据 


16.5.3 ”编辑 数据 
编辑 数据 也 是 数据 操作 中 最 常用 的 操作 之 一 ， 在 PHP 中 通过 mysqli 对 象 执行 SQL 语句 
UPDATE 就 可 以 对 数据 进行 修改 操作 ， 该 语句 的 语法 格式 如 以 下 代码 所 示 。 
”UPDATE 表 名 称 SET 列 名 称 = 新 值 WHERE 列 名 称 = 某 值 
因为 编辑 操作 通常 是 对 某 一 条 记录 进行 操作 ， 所 以 通常 需要 跟随 WHERE 子 句 来 限定 需要 


修改 的 字段 。 
下 面 的 例子 演示 了 如 何 将 id 为 1 的 数据 的 内 容 进 行 修改 。 


【示例 16-12】 编辑 数据 。 





执行 以 上 代码 ， 其 结果 如 图 16.16 所 示 。 
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| EE 
| Es hp p- OX 
em 


了 为 1 的 记录 修改 前 内 容 

Array ( [0] => 1 时 全 1 [1] => Mike [name] => Mike 
[2] => 男 [sex] => 男 [3] => 1990 [birthday] => 1990 ) 
ID 为 1 的 记录 修改 后 内 容 为 

Array ( [0] => 1 [id] => 1 [1] => Mike [name] => Mike 
[2] => 男 [sex] => 男 [3] => 2016 [birthday] => 2016 ) 





图 16.16 编辑 数据 


查看 图 16.15 记录 修改 前 后 的 对 比 结果 可 以 看 到 ， 修 改 之 后 生日 由 原来 的 1990 变 成 了 
2016。 通 常 修改 操作 可 以 配合 前 台 的 Web 表单 进行 ， 由 用 户 自行 输入 需要 修改 的 内 容 ， 然 后 在 
后 台 将 原 有 数据 修改 为 用 户 输入 的 内 容 。 


16.5.4 ”删除 数据 


如 果 表 中 的 某 些 数据 不 再 需要 ， 可 以 执行 删除 数据 操作 ， 执 行 SQL 语句 DELETE 即 可 删除 
数据 ， 其 语法 格式 如 下 所 示 。 


因为 删除 数据 通常 是 删除 某 一 个 ， 所 以 要 加 上 WHERE 子 句 以 限定 删除 条 件 ， 如 果 不 加 该 
子 句 ， 形 如 下 面 : 


这 样 会 删除 表 中 的 所 有 数据 。 


【示例 16-13】 删 除数 据 表 。 





执行 以 上 代码 就 会 删除 ID 为 1 的 数据 。 
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16.5.5 ”复杂 的 查询 


除了 常规 的 查询 之 外 ， 这 一 小 节 来 介绍 一 些 复杂 的 查询 ， 其 中 要 用 到 一 些 SQL 语句 的 其 他 
子 句 ， 以 实现 特定 的 复杂 查询 的 功能 。 


1. 多 条 件 查询 


前 面 介绍 过 ， 使 用 WHERE 子 句 可 以 实现 有 条 件 的 查询 ， 如 果 要 实现 多 条 件 查询 可 以 使 用 
AND 和 OR 来 实现 。 其 中 AND 是 “和 ”， 而 OR 是 “或 ”， 这 样 就 可 以 实现 多 条 件 查询 。 


以 上 代码 会 从 persons 表 中 查询 所 有 姓 为 “Carter” 同 时 名 为 “Thomas” 的 人 。 


以 上 代码 是 从 persons 表 中 查询 所 有 姓 为 “Carter” 或 者 名 为 “Thomas” 的 人 。 


2. 模糊 查询 


要 实现 模糊 查询 可 以 在 WHERE 子 句 中 使 用 LIKE 操作 符 ，LIKE 操作 符 的 语法 模式 如 以 下 
代码 所 示 。 


其 中 column_nams 为 需要 查询 的 列 名 称 ，table_name 为 表 的 名 称 ，pattern 为 模糊 查询 模式 ， 
其 中 可 以 使 用 通配符 “%” 来 实现 模糊 搜索 。 


以 上 代码 会 从 Persons 表 中 搜索 所 有 居住 城市 以 “N” 开 头 的 所 有 记录 内 容 。 


3. 对 查询 结果 排序 


在 很 多 情况 下 需要 对 查询 结果 进行 排序 ， 比 如 在 留言 板 中 按 最 后 留言 时 间 进 行 排序 等 ， 这 时 
可 以 使 用 ORDER BY 子 句 。ORDER BY 语句 默认 按照 升序 对 记录 进行 排序 。 如 果 希 望 按照 降序 
对 记录 进行 排序 ， 可 以 使 用 DESC 关键 字 。 


以 上 代码 是 查询 所 有 内 容 ， 并 且 把 结果 按照 公司 名 称 进行 排序 。 


4. 限制 结果 数量 

查询 的 结果 通常 是 不 可 控制 的 ， 即 有 多 少 条 结果 符合 查询 条 件 是 事先 不 知道 的 ， 但 这 会 很 不 
方便 。 因 为 有 的 情况 下 是 要 限制 返回 结果 数量 的 ， 比 如 留言 板 显示 留言 记录 每 页 显示 10 条 等 。 
这 时 可 以 使 用 LIMIT 子 句 ， 其 语法 格式 如 下 所 示 。 
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其 中 可 选 参数 offset 为 偏 移 量 ， 即 从 第 几 条 符合 的 结果 开始 显示 ， 如 果 不 使 用 该 参数 则 从 第 
一 条 开始 。 参 数 rows 为 需要 显示 的 条 数 。 

使 用 LIMIT 子 句 可 以 非常 方便 地 实现 分 页 效果 。 比 如 每 页 显示 10 条 记录 的 话 ， 第 1 页 就 可 
以 用 如 下 SQL 语句 实现 : 


SELECT * FROM table IIMIT 10 
以 上 SQL 语句 意 为 从 第 1 条 开始 ， 显 示 10 条 ， 即 1~10。 而 第 2 页 可 以 用 下 面 的 SQL 语句 


实现 : 
SELECT * FROM table LIMIT 11,10 
以 上 SQL 语句 意 为 从 第 11 条 开始 ， 显 示 10 条 ， 即 11~20。 


5. 其 他 高 级 查询 
除了 以 上 介绍 的 常规 查询 之 外 ，MySQL 中 还 有 以 下 几 类 较为 复杂 的 查询 : 


@ ”连接 查询 : 连接 是 区 别 关系 与 非 关系 系统 的 最 重要 的 标志 。 通 过 连接 运算 符 可 以 实现 
多 个 表 查 询 。 连 接 查询 主要 包括 内 连接 、 外 连接 等 。 

@。 子 查询 : 是 指 一 个 查询 语句 谋 套 在 另 一 个 查询 语句 内 部 的 查询 。 在 SELECT 子 句 中 先 
计算 子 查询 ， 子 查询 结果 作为 外 层 另 一 个 查询 的 过 滤 条 件 。 子 查询 中 常用 的 操作 符 有 
ANY、SOME、ALL、EXISTS、IN， 也 可 以 使 用 比较 运算 符 。 子 查询 可 以 添加 到 
SELECT、UPDATE 和 DELETE 语句 中 ， 而且 可 以 进行 多 层 嵌 套 。 

@ 合并 查询 结果 : 利用 UNION 或 UNION ALL 关键 字 ， 可 以 将 多 个 SELECT 语句 的 结 
果 组 合成 单个 结果 集 。 合 并 时 ， 两 个 表 对 应 的 列 数 和 数据 类 型 必须 相同 。 其 中 UNION 
关键 字 合并 查询 结果 时 ， 删 除 重复 的 记录 ， 返 回 的 行 都 是 唯一 的 。 而 UNION ALL 关 
键 字 合并 查询 结果 时 ， 不 删除 重复 行 。 


限于 篇 幅 ， 以 上 几 种 较为 复杂 的 查询 这 里 就 不 做 过 多 讲述 ， 有 兴趣 的 读者 可 以 去 查阅 相关 专 
业 书籍 以 了 解 更 多 这 方面 的 知识 。 


第 17 章 
使 用 RebBeanPHP 更 方便 地 管理 数据 


RebBeanPHP 是 一 个 极为 方便 的 零 配置 ORM (对 象 关系 管理 ) 类 库 。 零 配置 意味 着 没有 任 
何 配置 文件 ， 既 没有 XML 文件 ， 也 没有 annotations、YAML、INI 等 。RedBeanPHP 还 可 以 随 着 
代码 的 需要 修改 和 生成 数据 库 表 ， 兼 容 MySQL、SQLite、PostgreSQL。 使 用 RedBeanPHP 进行 
数据 库 相 关 的 开发 可 以 节约 大 量 的 时 间 。 


下 载 安装 RedBeanPHP 


RedBeanPHP 官方 网 站 为 http://www.redbeanphp.com， 下 载 页 面 httpy/wwwxredbeanphp.conydownload ， 
下 载 文件 解压 后 其 实 只 有 一 个 PHP 文件 rb.php， 如 图 17.1 所 示 。 





RedBeanpHp ai 


The Power ORM 


Download 


RedBeanPHP ships as a single, all-in-one tarball, thatsall you need to get started with 
RedBeanPHP.Simply extract the tar.gz file to the destination folder and include the 
rb.php file in your PHP script 


Did you check the system requirements? 


Download RedBeanPHP 4.3.1 re 


The latest stable version of RedBeanpHP. If you're new to RedBeanpHP thisis the 


recommended version to use. 


国 -ownioad nedeeanphp 


After downloading and extracting the file and include the rb-file in your PHP script. 








图 17.1 下 载 RedBeanPHP 
【示例 17-1】 安 装 RedBeanPHP。 
安装 RedBeanPHP 极为 简单 ， 将 rb.php 复制 到 c:xampp\htdocs， 新 建 一 个 文件 rbtest.php: 


<?php 
require once('rb.php'); 
2 
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使 用 Composer 安装 RedBeanPHP 也 十 分 简单 ， 执 行 如 下 命令 : 


composer 会 下 载 RedBeanPHP 到 vendor 目录 ， 新 建 rbtestphp: 


使 用 composer 管理 PHP 类 库 非常 方便 ， 关 于 composer 的 详细 使 用 方法 这 里 就 不 介绍 了 。 


了 .2 快速 开始 


【示例 17-2】 初 步 测试 RedBeanPHP。 


新 建 17-2.php: 





执行 完 以 上 代码 后 ，RedBeanPHP 自动 建立 了 user 表 ， 结 构 如 图 17.2 所 示 。 


Extra 


auto_incTement 





图 17.2 ”自动 建立 的 表 


这 个 表格 是 RedBeanPHP 根据 $user 对 象 的 需要 自动 建立 的 ， 让 我 们 看 看 有 什么 内 容 ， 如 图 
17.3 所 示 。 


w in set (0.01 sec 





图 173 表 的 内 容 
可 见 RedBeanPHP 将 $user 的 属性 都 存 到 user 表 中 了 。 
现在 把 这 个 $user 再 从 数据 库 中 取出 来 : 
// 接 着 上 边 的 代码 


load('user', 1); 
姓名 = $user 1->name \n"; 
姓名 = test 





$user 1 
echo "用 | 
// 输 出: 用 户 信息 : 








现在 需要 给 $user 增加 一 个 email 属性 : 
// 接 着 上 边 代码 
$user 1->email= 'test@test.com'; 


R: :store ($user 1); 


再 次 查看 数据 库 结构 和 内 容 ， 如 图 17.4 所 示 。 





图 17.4 数据 库 结构 和 内 容 


305 











除了 那 一 行 新 建 MySQL 用 户 的 语句 ， 我 们 一 行 其 他 的 MySQL 语句 都 没有 写 ， 
RedBeanPHP 做 了 新 建 表 、 修 改 表 、 插 入 数据 、 修 改 数据 的 所 有 工作 。 
现在 我 们 来 做 清理 工作 ， 删 除 Suser 对 象 : 


R::trash ($user 1); 


// 将 $user 1 删除 了 








执行 这 段 代码 后 ，user 表 就 空 了 ， 如 图 17.5 所 示 。 


IySqdl1> select 半 from UseT 
mpty set (0.00 sec 





图 17.5 清空 表 
也 可 以 删 掉 整个 user 表 : 


R: :wipe('user'); 


// 和 危险 操作 ， 请 确认 安全 后 再 执行 
以 上 我 们 执行 了 几 个 重要 方法 ， 在 这 里 总 结 一 下 : 


@ Dispense: 新 建 。 
@ store: 存储 。 
@ load: 加 载 。 
@ trash: 删除 。 


RedBeanPHP 的 CRUD 


上 节 快 速 地 讲 了 RedBeanPHP 的 使 用 方法 ， 本 节 将 详细 讲述 CRUD 即 C: create，R: 
retrieve, U: update, D: delete。 


17.3.1 Create (新 建 〉 数据 对 象 
使 用 dispense 方法 新 建 对 象 ， 例 如 : 


$book= R::dispense('book'); 


// 新 建 一 个 book 对 象 
也 可 以 新 建 多 个 对 象 ， 返 回 的 是 数组 ， 例 如 : 


Sbooks= R::dispense('book', 10); 
// 新 建 了 10 个 book 对 象 ， 返 回 数组 
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用 dispenseAll 方法 可 以 同时 新 建 属于 不 同 表 的 对 象 ， 例 如 ; 


list( $books , $pages)= R::dispenseAll ('book*2,page*3°'); 

// 新 建 了 2 个 book 对 象 和 3 个 page 对 象 

// 返 回 一 个 多 维 数组 

dispense 接受 的 表 名 称 只 能 是 数字 和 小 写字 母 的 组 合 ， 例 如 : ltest、2abc、test、test123 都 
是 合法 的 参数 ， 而 Atest、a_user 是 不 合法 的 。 

RedBeanPHP 新 建 的 表 会 自动 建立 一 个 整形 字段 id 为 表 的 主键 ， 如 图 17.6 所 示 。 





int (11) unsigne' 


图 17.6 id 为 表 的 主键 





这 个 字段 还 设置 了 auto_increment 属性 ， 即 有 新 的 数据 插入 表 中 的 时 候 ，id 会 自动 增加 1， 
保证 其 值 的 唯一 性 。 

由 RedBeanPHP 新 建 的 对 象 可 以 设置 属性 ， 属 性 的 名 称 为 数字 和 字母 的 混合 ， 例 如 : 

S$testl= R::dispense('test1'); 

Stest1->name= 'name'; 

S$test1->fieldl='fieldl'; 

由 于 PHP 语法 的 限制 ， 对 象 的 属性 名 称 不 能 用 数字 开头 ， 然 而 数据 库 字 段 名 称 可 以 用 数字 
开头 ， 我 们 可 以 用 另 一 种 语法 绕 过 这 一 限制 ， 例 如 : 

$testl['2field']= '2field'; 

R::store($test1); 


看 看 testl 表 的 结构 ， 如 图 17.7 所 示 。 


Oo_increment 


name 


fieldl 





图 17.7 testl 表 的 结构 
另外 属性 名 称 如 果 使 用 Camel case 〈 即 每 个 单词 首 字 母 大 写 ) 方式 的 话 会 被 自动 转 为 camel 
case〈 即 每 个 单词 被 下 划 线 隔 开 ) ， 并 全 部 转 为 小 写字 母 〈 如 图 17.8 所 示 ) ， 例 如 : 


Stest1->isCamelCase = 'camel case'; // 字 段 名 : is camel case 
Ri: :Store (S$test1) ; 
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int 
va 





图 17.8 小 写字 母 的 表 结构 


17.3.2 ”Retrieve (获取 ) 数据 
获取 数据 有 两 种 情况 : 一 种 是 已 知 主键 值 ， 需 要 获取 数据 ; 另 
库 。 我 们 先 说 第 一 种 情况 ， 例 如 : 


-种 情况 是 设置 条 件 查询 数据 


$book = R::load('book', 1); 
// 已 知 主键 值 为 1， 获 取 数 据 到 $book 





第 二 种 情况 在 17.4 节 中 详细 介绍 ， 这 里 只 举 个 简单 的 例子 : 


$books= R::find('book', ‘id=1°'); 
// 用 find 方法 查询 数据 库 


be 
村 find 方法 返回 的 是 一 个 数组 


如 果 没 有 找到 数据 ，find 方法 返回 空 数组 ，load 方法 返回 false， 例 如 : 
$book= R::load('book', 1); 
if ($book){ 
echo ' 找 到 了 '; 
1 


17.3.3 Update 〈 更 新 ) 数据 

Update 数据 首先 要 获取 数据 ， 调 用 load 或 find 方法 获取 数据 后 ， 直 接 对 需要 修改 的 字段 赋 
值 ， 然 后 调用 store 方法 保存 即 可 ， 例 如 : 

$book= R::load('book', 1); 


$book->title='a test book'; 
R::store ($book); 


17.3.4 ”Delete 〈 删 除 ) 数据 
Delete 数据 调用 trash 方法 ， 例 如 : 
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也 可 以 一 次 删除 多 个 数据 ， 例 如 : 





] 了 . 作 查询 数据 库 


使 用 find 方法 可 以 查询 数据 库 ，find 方法 其 实 是 生成 并 执行 一 个 select 语句 ， 然 后 返回 查询 
结果 。 另 外 ，exec 方法 可 以 执行 SQL 语句 ， 还 有 一 组 get 方法 可 以 执行 SQL 语句 并 返回 数组 形 
式 的 结果 。 


17.4.1 查询 参数 绑 定 


查询 数据 库 就 会 有 查询 条 件 ， 其 中 用 到 的 可 变 部 分 就 是 查询 参数 。 如 果 查 询 参 数 来 源 是 安全 
的 ， 那 么 直接 写 到 查询 语句 中 即 可 ， 例 如 : 


如 果 查 询 参数 的 来 源 是 用 户 输入 ， 那 么 就 必须 用 参数 绑 定 来 执行 查询 ， 这 样 RedBeanPHP 
会 自动 对 绑 定 的 参数 进行 安全 过 滤 ， 例 如 : 


参数 绑 定 有 两 种 方式 ， 一 种 使 用 ? 来 代表 一 个 参数 ， 例 如 : 


在 这 里 ，find 方法 的 第 三 个 参数 是 个 数组 ， 按 照 ? 的 顺序 和 数量 提供 参数 的 值 。 
RedBeanPHP 会 自动 对 参数 值 进行 安全 过 滤 。 
另 一 种 则 是 给 参数 起 个 名 字 ， 例 如 : 


在 这 里 ，:idl 、:id2、:id3 就 是 参数 的 名 字 ，find 方法 第 三 个 参数 是 数组 ， 以 参数 名 为 键 提供 
参数 值 ， 这 里 无 须 考虑 顺序 问题 。 
以 下 的 所 有 find 和 get 函数 都 可 以 使 用 参数 绑 定 。 
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17.4.2 findoOne 方法 


find 方法 总 是 返回 一 个 数组 ， 如 果 没 有 符合 查询 条 件 的 结果 则 返回 空 数 组 。findOne 方法 类 
似 于 1oad 方法 ， 仅 返回 一 个 数据 ， 如 果 没有 符合 条 件 的 结果 则 返回 null。 


荔 即使 有 多 个 结果 ，findOne 方法 也 仅仅 返回 第 一 个 。 
例如 : 


17.4.3 ”findAll 方 法 
findAll 方法 其 实 和 find 方法 是 一 样 的 ， 常 用 于 执行 类 似 于 select * from book 这 样 的 语句 ， 


例如 : 


17.4.4 findCollection 方法 


如 果 需 要 返回 的 数据 量 较 大 ， 应 该 使 用 findCollection 方法 。 

其 他 find 方法 都 是 先 将 全 部 的 查询 结果 读 取 到 内 存 中 ， 转 换 为 PHP 对 象 和 数组 〈 在 
RedBeanPHP 中 叫做 Bean) ， 这 样 做 的 好 处 是 操作 起 来 比较 方便 ， 但 是 会 消耗 大 量 内 存 ， 如 果 
查询 结果 只 有 几 百 条 的 话 没 问题 ， 如 果 查 询 结果 有 几 十 万 条 就 会 耗 尽 系统 内 存 ， 无 法 正常 运行 。 

findCollection 方法 则 每 次 读 取 一 条 数据 ， 转 换 为 PHP 对 象 返 回 ， 然 后 再 读 取 下 一 条 数据 ， 
这 样 的 处 理 方式 即使 再 多 的 数据 也 不 会 用 多 少 内 存 ， 例 如 : 


在 实际 项 目 中 如 果 需 要 循环 处 理 大 量 数 据 的 时 候 尽 可 能 使 用 findCollection 方法 ， 这 样 节约 
内 存 。 


17.4.5 findLike 方法 
如 果 查 询 条 件 需要 对 某 个 字段 进行 多 个 比较 判断 ， 用 findLike 比 其 他 方法 更 加 方便 ， 例 如 : 
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使 用 findLike 的 代码 更 容易 维护 和 管理 ， 尤 其 是 需要 比较 的 数据 来 自 一 个 数组 的 时 候 更 加 方 
便 ， 例 如 : 


17.4.6 findOrCreate 方法 





findOrCreate 方法 很 实用 ， 这 个 方法 按照 查询 条 件 搜索 数据 库 ， 如 果 没有 找到 数据 则 使 用 查 
询 条 件 新 建 数据 ， 然 后 返回 这 个 数据 。 

什么 情况 特别 实用 呢 ? 考虑 以 下 情景 : 

电子 商务 网 站 新 建 商 品 ， 编 写 一 段 通用 代码 设置 通用 的 商品 属性 ， 使 用 findOrCreate 方法 创 
建 一 个 新 商品 ， 然 后 再 设置 商品 的 特殊 属性 ， 最 后 保存 。 





本 局 可 以 将 设置 通用 属性 的 代码 放 在 一 个 函数 中 便于 维护 。 


17.4.7 findMulti 方 法 
findMulti 方法 可 以 一 次 返回 多 个 表 中 的 数据 ， 例 如 : 


一 次 性 将 book 和 相关 的 page 都 取出 来 了 。 


17.4.8 getAll 方法 
getAll 方法 执行 一 个 select 语句 ， 以 多 维 数组 方式 返回 结果 ， 例 如 : 


以 上 代码 输出 一 个 如 下 格式 的 数组 : 
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可 以 用 foreach 或 其 他 任何 数组 函数 来 处 理 getAll 返回 的 结果 ， 但 是 由 于 返回 的 不 是 对 象 ， 
无 法 用 R::store 保存 回去 了 。 





17.4.9 getRow、getCol、getCell 方法 


getRow 方法 以 数组 形式 返回 查询 结果 的 第 一 行 ，getCol 方法 以 数组 形式 返回 查询 结果 第 一 
列 ，getCell 方法 返回 查询 结果 的 第 一 行 第 一 列 的 值 ， 参 考 表 17.1。 





getCell 常用 于 获取 MySQL 函数 结果 ， 例 如 : 





getRow 只 返回 第 一 行 ， 即 使 数据 库 中 有 更 多 结果 也 会 忽略 ， 例 如 : 





getCol 只 返回 第 一 列 ， 例 如 : 
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17.4.10 getAssoc 方法 


getAssoc 方法 返回 一 个 数组 ， 键 名 是 第 一 个 字段 ， 如 果 查 询 结果 只 返回 两 个 字段 ， 则 键 值 是 
第 二 个 字段 ， 如 果 多 于 两 个 字段 ， 则 键 值 是 一 个 数组 ， 数 组 的 内 容 是 第 二 个 至 最 后 一 个 字段 的 
值 ， 例 如 : 





民 司 如 果 键 名 重复 则 会 被 后 面 出 现 的 数据 覆盖 。 


17.4.11 count 方 法 


实际 项 目 中 经 常 需要 获取 一 个 SQL 查询 语句 的 总 量 ， 在 RedBeanPHP 中 使 用 count 方法 就 
可 以 了 ， 例 如 : 
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1/ 获取 book 表 的 数据 阁 量 


count 方法 和 find 的 语法 是 一 样 的 ， 例 如 : 
Sbook count= Ri:count('book' ，"id>? [01D); 


7 了 操作 数据 库 


17.5.1 exec 方 法 
使 用 exec 方法 直接 执行 SQL 语句 ， 例 如 : 


17.5.2 getlnsertID 方法 


如 果 使 用 exec 执行 了 insert 语句 ， 执 行 成 功 只 会 返回 true， 如 果 需 要 获取 新 建 数据 的 id 就 
要 调用 getInsertId 方法 ， 例 如 : 





17.5.3 inspect 方法 
使 用 inspect 方法 可 以 查看 数据 库 中 有 多 少 表 ， 以 及 表 中 的 字段 信息 ， 例 如 : 





可 以 看 出 来 键 名 是 字段 名 ， 键 值 是 字段 的 类 型 。 
如 果 不 传 入 任何 参数 ， 则 会 返回 所 有 的 表 名 称 ， 例 如 : 
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17.5.4 ”切换 数据 库 


RedBeanPHP 的 setup 方法 可 以 连接 一 个 数据 库 ， 如 果 需 要 连接 另 一 个 数据 库 的 话 可 以 使 用 
addDatabase 方法 添加 一 个 数据 库 连 接 ， 然 后 用 selectDatabase 切换 数据 库 ， 例 如 : 





17.5.5 ”事务 


MySQL 的 InnoDB 存储 引擎 支持 事务 处 理 ， 如 果 是 使 用 RedBeanPHP 建立 的 表 ， 默 认 都 是 
使 用 InnoDB 存储 引擎 。 

RedBeanPHP 有 两 种 方式 来 编写 事务 处 理 代码 ， 第 一 种 使 用 传统 的 begin/commitrollback 方 
法 ， 例如 : 





第 二 种 方式 利用 了 PHP 的 回调 函数 特性 ， 使 用 一 个 transaction 方法 即 可 ， 例 如 : 
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17.5.6 ”冻结 数据 库 


RedBeanPHP 可 以 根据 代码 自动 修改 数据 库 表 中 的 字段 ， 新 建 表 ， 甚 至 删除 整个 表 ， 但 是 当 
项 目 代 码 完 成 后 ， 应 该 去 掉 这 一 功能 ， 因 为 数据 库 这 个 时 候 已 经 不 需要 修改 了 ， 而 且 去 掉 这 一 功 
能 还 会 提高 一 点 性 能 ， 因 为 RedBeanPHP 无 须 比较 代码 和 表 的 差异 。 

用 freeze 方法 来 冻结 数据 库 ， 即 数据 库 无 须 RedBeanPHP 修改 了 ， 例 如 : 


freeze 方法 也 接受 传 入 一 个 数组 ， 这 个 数组 中 的 表 会 被 冻结 ， 不 在 这 个 数组 中 的 表 仍 然 可 以 
被 RedBeanPHP 修改 或 新 建 ， 例 如 : 


1 7.6 调试 RedBeanPHP 


17.6.1 ”startLogging、getLogs 方法 


开发 过 程 中 如 果 想 要 了 解 究竟 RedBeanPHP 执行 了 什么 SQL 语句 ， 就 要 用 到 startLogging、 
getLogs、stopLogging 方法 。 

startLogging/stopLogging 告诉 RedBeanPHP 开始 /停止 记录 的 SQL 语句 ，getLogs 则 以 数组 形 
式 返 回 记 录 的 结果 ， 例 如 : 
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17.6.2 debug 方法 


虽然 RedBeanPHP 提供 了 getLogs 方法 ， 但 是 getLogs 方法 会 将 绑 定 参数 与 SQL 语句 分 开 ， 
有 些 时 候 不 方便 查看 ， 例 如 : 





debug 方法 可 以 解决 这 个 问题 ， 例 如 : 





可 以 看 到 debug 方法 的 参数 有 两 个 ， 第 一 个 用 来 控制 是 否 开始 debug， 第 二 个 用 来 控制 log 
的 输出 模式 。 以 下 列 出 输出 模式 : 


0: 
1: 与 startLogging 相同 ， 绑 定 参 数 与 SQL 语句 分 开 ， 通 过 getLogs 获取 。 
2 

3: 通过 getLogs 获取 ， 绑 定 参 数值 填 入 到 SQL 语句 中 。 


直接 输出 。 


直接 输出 ， 绑 定 参 数值 填 入 到 SQL 语句 中 。 
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其 他 高 级 功能 


以 上 章节 介绍 了 RedBeanPHP 的 基础 用 法 ， 由 于 本 书 篇 幅 所 限 ， 其 他 的 高 级 功能 只 能 在 这 
里 简单 提 一 下 ， 有 需要 用 到 的 读者 请 参阅 官方 文档 。 

















17.7.1 关系 
MySQL 是 关系 型 数据 库 ，RedBeanPHP 支持 常见 的 一 对 多 、 多 对 一 和 多 对 多 ， 例 如 : 


$book= R: :dispense ('book'); 
Sbook->name='relationship'7 


$chapter= R::dispense('chapter') 
$chapter->name= 'chapter 1'; 


$book->ownChapterList[]= $chapter; 
R: :store ($book); 


上 边 这 段 代 码 执行 后 会 自动 创建 book 和 chapter 表 ， 两 个 表 结 构 如 图 17.9 所 示 。 


Default | Extra 


NULL 


+ 
| 
+ 
NULI | 
| 
+ 





图 17.9 两 个 表 的 结构 
可 以 看 到 chapter 表 有 个 book id 字段 与 book 表 关 联 。 建 立 关系 后 取出 来 非常 简单 ， 例 如 : 
$book= R: :findone ('book') 7 
foreach ($Sbook->ownChatperList as $chapter){ 
// 处 理 每 个 chapter 
} 
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17.7.2 Models 
RedBeanPHP 支持 MVC 模式 ， 可 以 基于 RedBeanPHP 提供 的 类 定义 一 个 自己 的 Model 类 ， 


例如 : 


17.7.3 ”复制 /克隆 
使 用 duplicate 方法 可 以 完整 地 复制 一 个 Bean， 包 括 其 关联 的 子 对 象 ， 例 如 : 





这 个 方法 极为 实用 ， 转 ww | 





17.7.4 ”导入 导出 
import 方法 可 以 从 一 个 数组 中 导入 到 一 个 Bean 对 象 ， 例 如 : 


import 方法 用 来 从 用 户 提交 的 数据 导入 到 Bean 对 象 最 为 实用 ， 但 是 要 注意 import 方法 本 身 
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并 不 检验 数据 ， 因 此 还 是 导入 后 用 Model 类 的 update 方法 来 检验 数据 。 
可 以 指定 导入 哪些 字段 ， 例 如 : 


export 方法 用 来 导出 Bean 对 象 到 数组 中 ， 例 如 : 


第 18 章 
使 用 PHP+MySQL 构 建 模拟 春 试 系统 


随 着 驾驶 资格 证 、 教 师资 格 证 、 会 计 证 等 各 种 类 型 的 证 照 考 试 的 兴起 ， 网 上 模拟 测试 变 得 越 
来 越 受 到 用 户 的 青睐 。 网 上 模拟 测试 可 以 方便 地 出 题 ， 并 在 第 一 时 间 给 出 测试 结果 。 而 使 用 
PHP 与 MySQL 结合 可 以 实现 网 上 考试 系统 的 各 项 功能 。 本 章 就 来 介绍 如 何 使 用 PHP+MySQL 
来 制作 一 个 模拟 考试 系统 ， 通 过 本 章 内 容 的 学 习 ， 读 者 将 会 了 解 到 如 何 使 用 PHP+MySQL 创建 
网 络 应 用 程序 。 


功能 分 析 


本 节 先 来 介绍 要 制作 的 模拟 考试 系统 的 各 项 功能 ， 根 据 功能 的 不 同 其 中 可 具体 分 为 三 大 功能 
模块 ， 每 个 模块 实现 系统 一 项 功能 ， 三 大 模块 分 别 为 : 注册 登录 模块 ;管理 员 功能 模块 、 普 通用 
户 功 能 模块 。 三 大 模块 独立 运作 又 相互 关联 ， 而 每 个 大 模块 中 又 可 细 分 为 若干 小 的 功能 模块 ， 其 
关系 如 图 18.1 所 示 。 





图 18.1 模拟 考试 系统 三 大 功能 模块 图 
其 中 注册 登录 模块 实现 用 户 注册 与 登录 ; 管理 模块 可 以 对 考试 系统 内 部 的 题目 进行 添加 、 删 
除 和 修改 等 操作 ; 用 户 模块 主要 实现 测试 、 查 看 历史 测试 成 绩 、 修 改 密码 等 操作 。 下 面 各 节 将 通 
过 具体 代码 来 实现 三 大 模块 各 自 的 功能 。 





准备 工作 


在 开始 实现 各 个 功能 模块 之 前 ， 先 要 做 一 些 前 期 准备 工作 ， 如 系统 所 需 数据 表 的 设计 、 相 关 
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配置 文件 的 创建 、 库 表 的 建立 等 。 这 一 节 先 来 做 这 些 准备 工作 ， 这 些 准备 工作 的 实现 为 下 面 各 个 
功能 模块 的 实现 黄 定 基础 。 


18.2.1 设计 数据 表 


由 于 本 章 所 介绍 的 模拟 考试 系统 仅 实现 了 基本 功能 ， 所 以 相关 表 的 内 容 比 较 少 ， 也 比较 简 
单 。 一 共 包 括 四 个 表 ， 分 别 是 : 用户 表 (user) 、 问 题 表 (question) 、 答 案 表 (answer) 、 测 试 
记录 表 (exam) 等 。 具 体内 容 如 表 18.1~ 表 18.4 所 示 。 


表 18.1 用 户 表 (user) 


类 型 
Er rs rr ET 
| name |VARCHAR |l2 | 用户 名 和 





[pass | VARCHAR |12 | 用 AP 密码 无 
hm hh | 


表 18.2 问题 表 (question) 
字段 类 型 长 度 意义 其 他 
[la mm 6 | 丁 pD | 键 自动 增加 | 
| content |vaRcHAR | 20 |[ 题 R 容 | 无 | 
Er re 
答案 (如 果 问 题 为 选择 题 ， 则 值 为 0; 
如 果 问 题 为 判断 题 ， 值 为 1 表示 结果 正 
确 ， 值 为 0 表示 结果 错误 ) 





表 18.3 答案 表 (answer) 
类 型 意义 


ECG EEC 
[ae YaRcHAR 2 | 无 


后 ID 什 ) 


| answer | NT |! | 答案 (如 果 是 答案 , 则 值 为 1; 反之 , 值 )) | 无 | 


表 18.4 测试 记录 表 (exam) 








id INT 6 测试 人 主键 、 自 动 增加 











| name | vARCHAR 200 考试 人 员 名 称 | 无 | 
| Score | INT 可 考试 分 数 | 无 | 
[an | mr 1 考试 日 期 | 无 | 





以 上 即 为 实现 该 模拟 考试 系统 所 需要 的 4 张 表 ， 表 与 表 之 间 互 相关 联 ， 其 中 问题 表 与 答案 表 
之 间 尤 为 密切 。 


322 


第 18 章 使 用 PHP+MySQL 构建 模拟 考试 系统 





18.2.2 ”创建 配置 文件 


PHP 支持 引用 外 部 文件 ， 这 样 的 好 处 是 可 以 把 某 个 常用 的 模块 在 一 处 定义 ， 多 处 调用 。 这 
样 可 以 减少 代码 的 反复 使 用 ， 另 外 如 果 需 要 对 代码 进行 改动 ， 只 需要 做 一 处 改动 即 可 ， 而 不 用 多 
处 改动 。 

因为 该 模拟 考试 系统 的 核心 是 对 数据 库 表 进行 操作 ， 所 以 调用 各 种 配置 、 连 接 服务 器 、 选 择 
数据 库 等 就 会 在 多 处 被 用 到 。 所 以 这 里 把 该 功能 单独 写 出 来 ， 以 便 程 序 多 处 调用 。 具 体 代码 如 下 
所 示 : 





将 该 代码 命名 为 :config.php， 以 备 后 用 。 

其 中 定义 了 连接 服务 器 所 需要 的 服务 器 名 称 、 用 户 名 、 密 码 、 数 据 库 以 及 各 个 表 的 名 称 等 。 
然后 创建 mysqli 对 象 ， 同 时 指定 需要 使 用 的 数据 库 名 称 ， 最 后 还 通过 对 象 的 query() 方 法 执行 
SQL 语句 将 默认 编码 设置 为 中 文 。 

由 于 以 上 代码 定义 了 配置 文件 ， 其 中 包含 服务 器 、 数 据 库 的 信息 ， 所 以 如 果 用 户 要 将 整个 程 
序 移动 的 其 他 服务 器 上 ， 或 者 在 另外 的 服务 器 上 安装 ， 只 需要 改动 该 配置 文件 中 的 相关 变量 即 
可 ， 这 样 可 以 方便 程序 的 迁移 。 


18.2.3 ”创建 安装 文件 


这 一 小 节 ， 我 们 来 创建 安装 文件 ， 通 过 执行 安装 文件 ， 可 以 在 目标 MySQL 服务 器 上 创建 该 
系统 所 需要 的 4 个 表 ， 并 且 还 会 根据 用 户 输入 ， 创 建 默认 的 系统 管理 员 账户 。 安 装 文件 的 具体 内 
容 如 以 下 代码 所 示 : 
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将 以 上 代码 保存 为 : instalphp， 执 行 代码 结果 如 图 18.2 所 示 。 


Ce | hapynz7oolii7mnaapm Pp - OX os 
[ee | 


输入 管理 员 信息 








输入 管理 员 名 称 ， 
输入 管理 员 密 码 : 























图 18.2 install.php 执行 界面 


代码 首先 判断 有 无 用 户 输入 内 容 ， 如 果 没 有 则 在 前 台 显示 一 个 表单 ， 让 用 户 输入 默认 的 管理 
员 名 称 与 密码 。 如 果 有 用 户 输入 内 容 ， 则 根据 设计 的 数据 表 ， 执 行 建 表 SQL 语句 ,创建 系 统 所 
需要 的 四 张 表 ， 并 将 用 户 输入 的 管理 员 名 称 与 密码 添加 到 用 户 表 中 。 

注意 ， 这 里 添加 用 户 输入 信息 时 ，admin 字段 为 1， 即 该 用 户 为 管理 员 ， 管 理 员 可 以 对 系统 
进行 各 种 管理 操作 。 


号 .了 用户 注册 与 登录 


用 户 是 该 系统 最 核心 的 环节 ， 所 有 操作 都 需要 用 户 来 完成 。 其 中 用 户 注册 与 登录 就 是 实现 系 
统 功能 的 基础 ， 只 有 用 户 登录 了 才能 执行 相关 操作 。 这 一 节 就 来 介绍 用 户 的 注册 与 登录 模块 。 


18.3.1 用 户 注册 


用 户 注册 分 前 台 与 后 台 两 部 分 内 容 ， 首 先 在 前 台 显示 表单 ， 用 户 可 以 输入 用 户 名 与 密码 ， 之 
后 转 入 后 台 。 后 台 会 判断 是 否 存在 重 名 用 户 ， 如 果 有 ， 则 提示 用 户 重新 返回 前 台 输入 ;如 果 没 
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有 ， 则 将 用 户 输入 内 容 添加 到 用 户 表 之 中 。 具 体内 容 如 以 下 代码 所 示 : 





| @ napyiz7oouirep - BO Xn oo 
[er 




















图 18.3 regphp 执行 界面 


18.3.2 ”用户 登 录 

用 户 登录 与 注册 类 似 ， 也 分 为 前 台 与 后 台 两 部 分 ， 前 台 供用 户 输入 用 户 名 及 密码 。 后 台 判 断 
是 否 存在 指定 用 户 并 且 密 码 正确 ， 如 果 不 存 在 或 者 密码 错误 ， 则 提示 用 户 重新 输入 。 如 果 存 在 同 
时 密码 正确 ， 则 使 用 setcookie() 将 用 户 登录 信息 写 入 Cookie 值 ， 提 示 用 户 进入 首页 。 

具体 内 容 如 以 下 代码 所 示 : 





327 


PHP+MySQL 网 站 开发 从 零 开始 学 〈 视 频 教 学 版 ) 】 





将 以 上 代码 保存 为 : login.php， 执 行 该 代码 可 以 完成 用 户 登录 的 操作 ， 如 图 18.4 所 示 。 


让 四-|@ hapyaz7ooyiogp > OX 0 
[Eze 


























图 18.4 login.php 执行 界面 


18.4 首页 


首页 是 各 个 功能 模块 的 连接 点 ， 通 过 首页 管理 员 可 以 进入 管理 页 面 执行 管理 操作 ， 普 通用 户 
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可 以 进入 考试 页 面 进行 考试 、 查 看 历史 成 绩 ， 也 可 以 执行 更 改 密码 、 退 出 登录 等 操作 。 其 中 还 需 
要 单独 创建 检查 登录 用 户 是 否 为 管理 员 的 代码 ， 方 便 管理 模块 调用 。 


18.4.1 首页 


首页 先 判断 用 户 是 否 登 录 ， 如 果 没 有 则 提示 用 户 登 录 ， 并 给 出 注册 与 登录 的 链接 。 如 果 已 经 
登录 再 判断 其 身份 ， 如 果 是 管理 员 ， 给 出 管理 页 面 链接 ; 如 果 是 普通 用 户 ， 则 输出 进行 测试 、 查 
看 历史 成 绩 等 页 面 链接 。 

具体 内 容 如 以 下 代码 所 示 : 





将 以 上 代码 保存 为 : index.php， 完 成 首页 模块 创建 。 执 行 界 面 如 图 18.5 所 示 。 
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欢迎 使 用 智能 考试 系统 ! 

你 还 没有 登录 ! 

登录 ”注册 
图 18.5 index.php 执行 界面 





18.4.2 ”检查 管理 员 


检查 登录 用 户 是 否 为 管理 员 是 登录 用 户 执行 所 有 管理 模块 的 前 提 ， 把 该 模块 单独 做 出 来 ， 可 
以 方便 各 个 管理 模块 调用 ， 同 时 减少 代码 见 余 。 其 内 容 如 以 下 代码 所 示 : 





将 以 上 代码 命名 为 : check_admin.php， 以 备 下 一 节 各 个 管理 模块 的 调用 。 


号 .5 管理 模块 


管理 员 可 以 对 系统 中 的 题库 进行 题目 遍历 、 查 看 题目 详情 、 添 加 题目 、 修 改 题目 、 删 除 题目 
等 操作 。 这 一 节 按 照 各 个 管理 模块 来 逐个 介绍 。 


18.5.1 显示 所 有 题目 


显示 所 有 题目 执行 普通 的 遍历 操作 ， 并 给 出 添加 题目 ， 以 及 对 指定 题目 的 查看 、 修 改 、 删 除 
操作 的 链接 ， 其 内 容 如 以 下 代码 所 示 : 
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将 以 上 代码 保存 为 : admin.php， 执 行 该 代码 即 可 对 所 有 题目 进行 查看 操作 ， 执 行 结果 如 图 
18.6 所 示 。 


"|@@ htpy1l2700317/adp ~ 明和 由 X no 


[FE 


题库 管理 





18.6 admin php 执行 结果 


331 








PHP+MySQL 网 站 开发 从 零 开 始 学 (视频 教学 版 ) 


18.5.2 ”添加 题目 


默认 情况 下 ， 系 统 中 没有 任何 题目 ， 如 果 没 有 题目 管理 员 就 无 从 谈 起 修改 、 删 除 ， 而 普通 用 
户 也 无 法 进行 考试 。 所 以 ， 首 先 需要 向 系统 中 添加 题目 。 

添加 题目 共 分 三 步 ， 第 一 步 ， 让 管理 员 选 择 题目 类 型 ， 共 有 单 选 题 与 判断 题 两 种 ， 第 二 步 根 
据 第 一 步 选择 ， 输 入 题目 内 容 及 选择 项 内 容 ; 第 三 步 将 管理 员 输 入 题目 相关 信息 添加 到 问题 表 与 
答案 表 中 。 

具体 内 容 如 以 下 代码 所 示 : 
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将 以 上 代码 保存 为 :add_question.php， 执 行 代码 即 可 完成 添加 题目 操作 。 执 行 结果 如 图 
18.7 所 示 。 


Oe wn - ao x 
Eze | 
添加 题库 
| 请 选择 题目 类 型 
古 目 类 型 | 选择 是 ~ 
-| 








图 18.7 add_question.php 执行 界面 


汪 册 添加 起 日 叶 ， 如 果 是 日 类 型 为 关 断 题 ， 则 题目 所 有 信息 在 问题 表 中 即 可 完成。 如 果 题目 类 型 


为 选择 题 ， 除 了 向 问题 表 中 添加 相关 内 容 之 外 ， 还 需要 向 答案 表 中 添加 信息 。 





18.5.3 ”显示 题目 详情 
在 显示 所 有 题目 页 面 中 只 能 看 到 题目 的 大 概 ， 看 不 到 题目 的 详情 ， 所 以 还 需要 单独 创建 一 个 
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显示 题目 详情 模块 。 其 中 除了 显示 题目 内 容 之 外 ， 判 断 题 还 需要 显示 题目 是 正确 还 是 错误 ， 选 择 
题 还 需要 显示 所 有 选择 项 并 给 出 哪 一 个 才 是 正确 答案 。 





将 以 上 代码 保存 为 : show_question.php， 执 行 该 代码 即 可 查看 指定 题目 的 详情 ， 执 行 结果 如 
图 18.8 所 示 。 
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四-|@ hapynzrooari7srop ~- OK 0 
[rz 


查看 题目 详情 
题目 类 型 ， 泛 择 题 
厦 目 内 容 ，|2016 美 国 当选 总 统 是 ? 


目 答案 : 








图 18.8 ”show_question.php 执行 结果 


et 显示 题目 详情 时 ， 需 要 前 台 提供 一 个 ID 值 ， 该 值 通过 显示 题目 页 面 使 用 GET 方式 进行 提 | 
供 。 只 有 该 值 才能 正确 显示 指定 题目 。 如 果 直 接 执行 代码 ， 相 当 于 无 ID 值 ， 则 不 会 正常 输 
出 内 容 。 





18.5.4 ”编辑 题目 


题目 在 创建 之 后 ， 并 不 是 一 成 不 变 ， 如 果 管理 员 发 现 题目 信息 有 误 ， 则 需要 对 题目 进行 编辑 
操作 。 对 于 判断 题 ， 管 理 员 可 以 修改 其 内 容 及 答案 ， 对 于 选择 题 ， 管 理 员 除了 可 以 修改 题目 内 
容 ， 还 可 以 修改 各 个 选择 项 的 内 容 ， 并 且 重 新 指定 正确 的 选择 的 项 。 
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将 代码 保存 为 : edit_question.php， 执 行 代码 可 以 对 指定 题目 进行 修改 操作 。 结 果 如 图 18.9 
所 示 。 


Oe wm - Bo x 














2016 美 国 当选 总 统 是 了 
奥巴马 
克林顿 
特 闻 苦 
希拉 里 


返回 


























18.9 edit_ question.php 执行 界面 
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[2 有 。 编辑 题目 时 ， 也 需要 前 台 提供 一 个 ID 值 ， 该 值 通过 显示 题目 页 面 使 用 GET 方式 进行 提供 。] 
如 果 无 ID 值 ， 则 不 会 正常 输出 内 容 。 





18.5.5 “删除 题目 


对 于 已 经 不 再 符合 考试 要 求 的 题目 ， 管 理 员 可 以 将 其 从 题目 列表 中 删除 。 对 于 判断 题 ， 只 需 
要 从 问题 表 中 删除 题目 即 可 ， 而 对 于 选择 题 除 了 删除 题目 本 身 ， 还 需要 删除 答案 表 中 与 其 对 应 的 
选择 项 。 
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将 以 上 代码 保存 为 : del_question.php， 执 行 代码 删除 题目 操作 。 结 果 如 图 18.10 所 示 。 


C0 @ hapwzrooanzydcp - OX Lo 
[EE | 


焉 目 内 容 ， |2016 美 国 当选 总 统 是 ? 
CE 





图 18.10 del_question .php 执行 界面 
LE 胸 员 。 间 除 题目 与 显示 详情 及 编辑 题目 类 仪 ， 也 需要 前 台 提供 一 个 ID 值 ， 该 什 通 过 显示 题目 页 面 | 
使 用 GET 方式 进行 提供 。 如 果 无 ID 值 ， 则 不 会 正常 输出 内 容 。 






号.6 用 户 模块 


上 一 节 介 绍 的 是 管理 员 模块 ， 这 一 节 来 介绍 用 户 模块 。 用 户 模块 主要 包括 : 进行 考试 、 查 看 
历史 考试 记录 、 更 改 密码 以 及 退出 登录 等 。 下 面 来 逐个 介绍 各 个 功能 模块 。 


18.6.1 ”考试 页 面 


进入 考试 页 面 ， 系 统 会 自动 随机 从 题库 中 选择 指定 数据 的 单项 选择 题 与 判断 题 ， 并 提供 选择 
界面 ， 让 用 户 进行 答题 操作 。 在 用 户 提交 所 答 问题 之 后 ， 系 统 会 自动 在 后 台 对 所 答 内 容 进行 判 
断 ， 并 计算 出 得 分 。 之 后 还 会 把 用 户 的 考试 结果 存 入 exam 表 中 。 

具体 内 容 如 下 所 示 : 
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将 以 上 代码 保存 为 : testphp， 执 行 代码 即 可 进行 考试 。 结 果 如 图 18.11 所 示 。 
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所 局 二 
[ER 
葡 迎 使 用 知 能 考试 系统 ! 

欢 提 称 ，guest 

现在 开 冯 考试 
一 、 渤 择 题 [每 题 1 分 ) 
1、2016 美 国 当选 总 统 量 ? 
站 奥巴马 自 





图 18.11 考试 页 面 执行 结果 


在 随机 获取 库存 中 指定 数量 题目 记录 时 ， 使 用 了 order by randO 子 句 ， 该 子 句 效率 较 低 ， 不 
过 在 总 库存 题目 较 少 〈 万 条 以 下 ) 时 ， 几 乎 感觉 不 到 。 





18.6.2 ”查看 历史 考试 记录 


经 过 数 次 考试 ， 登 录用 户 可 以 随时 查看 自己 的 历史 考试 成 绩 ， 只 需要 对 exam 表 执 行 遍历 操 
作 即 可 。 
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将 以 上 代码 保存 为 : exam.php。 执 行 代码 首先 判断 用 户 是 否 登录 ， 如 果 用 户 登录 之 后 ， 还 要 
看 是 否 进行 过 考试 ， 只 有 进行 过 考试 才 会 显示 相关 内 容 。 结 果 如 图 18.12 所 示 。 


[Oo wnnonm..  - ao x rs 
[Emm 


欢迎 使 用 智能 考试 系统 ! 


查看 用 户 guest 的 历史 考试 成 绩 
共有 1 条 历史 考试 记录 


序号 用 户 成绩 诸 坛 日 其 
[I leuestls [2016-11-16 13:54:41 
返回 











图 18.12 查看 历史 考试 记录 


18.6.3 更改 密码 
不 管 是 普通 用 户 或 者 管理 员 都 可 以 对 其 注册 时 填写 的 密码 进行 修改 。 因 为 更 改 密码 是 对 于 管 
E 员 和 普通 用 户 都 可 以 执行 的 操作 ， 这 里 将 其 放 到 用 户 模块 中 进行 介绍 。 


瞄 
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将 以 上 代码 保存 为 : edit_pass.php， 执 行 代码 对 登录 用 户 的 密码 进行 修改 操作 。 结 果 如 图 
18.13 所 示 。 


DB | @ naparoo ep - BO Xn os 
em | 


欢迎 使 用 智能 考试 系统 ! 











图 18.13 更 改 密码 


18.6.4 ”退出 登录 


如 果 用 户 不 想 再 使 用 该 系统 ， 就 需要 安全 退出 ， 这 样 做 可 以 保证 用 户 信息 的 安全 。 安 全 退出 
的 实质 是 用 空 值 重 写 COOKIE， 这 样 就 相当 于 COOKIE 中 不 再 保存 任何 用 户 登 录 信息 ， 从 而 保 
证 用 户 信息 的 安全 。 





将 代码 保存 为 exitphp， 用 户 在 首页 面 单 击 退出 登录 就 会 执行 该 代码 。 


346 


第 19 章 
使 用 PHP+MySQL 构 建 在 线 购物 网 站 


随 着 人 们 消费 观念 的 改变 ， 越 来 越 多 的 人 开始 习惯 网 上 购物 ， 各 种 在 线 购物 网 站 (如 : 天 
猫 、 淘 宝 、 京 东 等 ) 发 展 的 风 生 水 起 ， 特 别 是 每 年 的 双 11 更 是 成 为 网 上 购物 爱好 者 的 狂欢 节 。 
各 种 购物 网 站 归根 结 底 还 是 程序 与 数据 的 操作 ， 使 用 PHP 结合 MySQL 数据 库 也 可 以 非常 方便 
地 制作 出 在 线 购物 网 站 。 当 然 要 实现 一 个 像 淘 宝 那样 功能 完备 、 内 容 丰富 的 整 站 系统 也 并 非 不 可 
能 ， 读 者 可 以 以 此 为 基础 不 断 进行 扩展 。 





功能 分 析 


在 开始 实际 创建 在 线 购物 网 站 之 前 ， 本 节 先 了 解 一 下 本 章 介绍 的 购物 网 站 所 采用 的 数据 表 结 
构 及 其 算法 。 了 解 这 些 内 容 对 于 开始 实际 创建 相关 的 功能 模块 将 起 到 事半功倍 的 效果 。 


19.1.1 设计 算法 


本 章 所 要 介绍 的 MINI 在 线 购物 网 站 内 容 由 一 系列 的 商品 类 别 、 商 品 及 用 户 构成 。 而 用 户 又 
可 区 分 为 管理 员 与 普通 用 户 。 普 通用 户 具 有 浏览 商品 、 购 买 商品 、 查 看 注册 信息 、 更 改 密码 、 查 
看 历史 订单 等 权限 。 归 根 结 底 不 管 是 管理 员 还 是 普通 用 户 其 所 操作 的 对 象 都 是 商品 。 其 逻辑 关系 
及 所 有 操作 如 图 19.1 所 示 。 


























[购买 物品 处 理 订单 | 
[二 || | [十 | | | 添加 类 别 商品 
| 修改 用 户 密码 | | | 修改 类 别 商品 




















图 19.1 MINI 在 线 购物 网 站 内 容 及 操作 简 图 
查看 图 19.1 可 以 看 到 ， 本 章 所 要 介绍 的 购物 网 站 的 大 致 结构 及 各 功能 模块 。19.1.2 节 就 来 介 
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绍 涉及 以 上 各 功能 模块 中 的 表 的 设计 。 


19.1.2 ” 表 的 设计 

确定 了 购物 网 站 的 程序 结构 ， 本 节 就 来 设计 表 的 内 容 。 这 里 按照 购物 网 站 中 所 需要 的 各 项 内 
容 共 需 要 设计 四 个 表 ， 分 别 是 用 户 表 、 商 品种 类 表 、 商 品 表 及 订单 表 等 。 这 四 个 表 分 别 用 于 存储 
该 系统 所 需要 的 四 种 资源 。 

1. 用 户 表 的 没 计 


首先 来 设计 用 户 表 。 购 物 网 站 离 不 开 买 家 与 卖家 ， 所 有 的 买 家 与 卖家 都 将 以 用 户 形式 出 现 。 

用 户 表 用 于 存储 所 有 用 户 的 信息 。 由 于 本 章 所 介绍 的 系统 仅 实现 最 基本 的 功能 ， 所 以 用 户 表 的 设 
计 也 仅 包 含 最 基本 的 内 容 。 用 户 表 的 具体 设计 内 容 如 表 19.1 所 示 。 
表 19.1 用 户 表 (mini_user) 的 设计 内 容 





类 型 长 度 
| Er 
| name | varchar(12) | E 其 内 容 为 用 户 注册 时 填写 的 什 


用 户 密码 ， 其 内 容 为 用 户 注册 时 所 输入 的 密码 ， 一 一 
password varchar(40) 加 密 


| email | vachargm | 用 PFi 箱 二 | 
| eg date | varchar20) | 注册 日 期 如 2012 年 ?有 3 虽 | | 
管理 员 标识 ， 如 果 其 值 为 1， 则 为 管理 员 (拥有 更 多 权 
限 ) ;如 果 为 0， 则 为 普通 用 户 ， 默 认 值 为 0 


2. 商品 类 别 表 的 设计 


商品 类 别 表 用 于 保存 所 有 商品 的 种 类 。 因 为 一 个 商城 中 不 同 商品 应 该 分 门 别 类 以 便于 存放 ， 
所 以 专门 使 用 一 个 商品 类 别 表 。 本 章 所 介绍 的 购物 网 站 仅 用 于 实现 最 基本 的 分 类 ， 所 以 没有 采用 
多 级 分 类 的 设 定 ， 仅 使 用 了 一 级 分 类 。 商 品类 别 表 的 具体 设计 内 容 如 表 19.2 所 示 。 
表 19.2 商品 类 别 表 (mini_type) 的 设计 内 容 





类 型 长 度 含义 
标识 ID 
name | varchar(12) 类 别名 称 
description | varchar(80) 类 别 介绍 
本 类 别 所 有 的 商品 总 数量 。 注 意 这 里 的 数量 是 指 可 出 售 
的 个 数 ， 而 非 商 品种 类 数 











num 





3. 商品 表 的 设计 


商品 表 用 于 存放 所 有 商品 的 具体 信息 ， 同 样 由 于 实现 最 基本 的 功能 ， 所 以 其 字段 数 较 少 ， 实 
际 使 用 中 可 以 为 其 扩充 更 多 的 字段 内 容 。 商 品 表 的 具体 设计 内 容 如 表 19.3 所 示 。 
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表 19.3 商品 表 (mini_goods) 的 设计 内 容 


字段 名 类 型 长 度 


含义 
name varchar(40) 商品 名 称 
type 





商品 所 属 类 别 ， 该 值 对 应 于 商品 类 别 表 指定 类 别 的 ID 
值 

cost 商品 售 价 

description 商品 介绍 


[mm Tm [wm#i | 
4. 订单 表 的 设计 
订单 表 用 于 存放 用 户 通过 购物 车 所 生成 的 订单 ， 订 单 按 其 状态 可 分 为 未 处 理 订单 与 已 处 理 订 
单 两 类 。 其 具体 设计 内 容 如 表 19.4 所 示 。 
表 19.4 订单 表 (mini_sales) 的 设计 内 容 











类 型 长 度 


下 芭 其 他 
int9) 主键 自 增 


订购 的 商品 ID， 其 值 对 应 商品 表 中 的 ID 值 | | 


sale goods num | int(5) 订购 商品 的 数量 ， 其 值 范围 为 从 1 到 该 类 商品 存货 量 最 大 值 | | 
订购 商品 时 的 售 价 ， 其 值 对 应 商品 表 中 的 cost 什 | | 
订单 状态 ， 如 果 其 值 为 1， 说 明 订 单 已 经 处 理 ， 如 果 其 值 为 

0， 则 说 明 订单 未 处 理 ， 其 默认 值 为 0 


下 订单 的 日 期 ， 其 值 为 下 订单 时 的 日 期 [ES 


sale_state enum('1','0') 








关于 该 在 线 购物 网 站 所 需要 的 四 个 表 的 设计 就 介绍 到 这 里 ，19.2 节 将 具体 实现 在 线 商 城 程 序 
的 功能 模块 。 





= 上 
和 


口 9 

了 。 人 ”准备 工作 

19.1 节 为 读者 介绍 了 在 线 购物 网 站 的 基本 原理 ， 还 设计 了 程序 所 需要 的 表 结 构 。 本 节 将 用 具 
体 的 代码 实现 所 要 求 的 全 部 功能 模块 。 


19.2.1 配置 文件 


在 开始 所 有 内 容 的 创建 之 前 ， 需 要 做 必要 的 准备 工作 ， 即 创建 相应 的 表 。 首 先 创建 供 所 有 页 
面 调用 的 配置 文件 ， 该 配置 文件 的 作用 就 是 创建 到 MySQL 数据 库 服务 器 的 连接 并 且 选 择 相应 的 
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库 。 其 具体 内 容 如 下 : 





以 上 代码 不 仅 分 别 定义 了 服务 嚣 名称、 连接 用 户 、 连 接 密 码 、 操 作 库 名 称 等 内 容 ， 而 且 还 定 
义 了 四 个 表 的 名 称 ， 这 样 在 程序 需要 改变 表 的 名 称 时 ， 只 需要 改变 配置 文件 即 可 ， 而 不 需要 修改 
每 个 功能 模块 中 的 具体 值 。 配 置 文件 使 用 默认 的 用 户 名 及 密码 连接 到 服务 器 并 且 选 择 了 test 库 ， 
并 设置 编码 为 GB2312。 用 户 在 使 用 时 ， 要 根据 自己 的 实际 内 容 更 改 其 中 的 用 户 名 、 密 码 及 数据 
库 名 称 等 内 容 。 将 以 上 代码 保存 为 config.php， 这 样 便于 其 他 程序 页 面 调用 该 配置 文件 。 


19.2.2 ”安装 模块 


创建 完 配置 文件 后 ， 再 来 创建 整个 系统 的 安装 文件 ， 该 安装 文件 由 前 台 与 后 台 两 部 分 组 成 。 
前 台 供用 户 填写 系统 管理 员 的 相关 信息 与 默认 商品 类 别 信息 ， 后 台 则 按照 这 些 信息 及 19.1.2 节 表 
的 设计 创建 系统 所 需要 的 4 个 表 。 安 装 文件 的 具体 内 容 如 下 : 
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以 上 代码 首先 调用 配置 文件 ， 连 接 到 数据 库 ， 然 后 分 别 定义 创建 商城 系统 所 需要 的 四 个 表 的 
SQL 语句 并 执行 。 然 后 还 按照 用 户 输入 的 内 容 添加 管理 员 与 默认 类 别 。 最 后 根据 执行 结果 输出 
不 同 的 内 容 。 将 以 上 代码 保存 为 install.php， 执 行 该 代码 ， 其 执行 结果 如 图 19.2 所 示 。 






| 四 -je mpynazoousmsp - BO XK 0 
[ew | 


mini 商 城 系统 支 装 程 序 

































19.2 ”商城 系统 安装 模块 前 台 
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在 图 19.2 中 按照 要 求 输入 管理 员 相关 信息 及 默认 类 别 信息 ， 单 击 “ 确 认 安装 ”按钮 ， 将 转 
入 后 台 进行 处 理 。 如 果 安 装 成 功 执行 ， 则 结果 如 图 19.3 所 示 。 


Ca) hpi2700unsint p> OX oo 
[em 
成 功 安装 mini 商 城 系统 ! 
点 这 里 注册 新 用 户 ” 点 这 里 登录 





19.3 ”商城 系统 安装 模块 后 台 


1 日. 了 注册 登录 模块 


19.2 节 介绍 了 实现 整个 在 线 购物 网 站 所 要 求 的 全 部 功能 模块 。 按 其 功能 可 划分 为 注册 登录 相 
关 、 查 看 商品 相关 、 查 看 用 户 信息 相 关 、 添 加 与 编辑 类 别 、 添 加 与 编辑 商品 、 处 理 订单 及 退出 登 
录 等 。 本 节 来 实际 运行 这 几 个 功能 模块 ， 查 看 其 是 否 能 够 按照 既定 的 规划 方案 执行 。 


19.3.1 注册 模块 


本 节 创建 用 户 注册 模块 。 虽 然 商城 系统 在 安装 时 添加 了 默认 管理 员 用 户 ， 但 普通 用 户 的 使 用 
仍然 需要 通过 注册 来 实现 。 该 系统 规定 ， 非 注册 用 户 可 以 随意 浏览 所 有 商品 内 容 ， 但 却 不 能 购买 
商品 ， 所 以 需要 注册 才能 体验 系统 的 所 有 功能 。 注 册 模 块 可 以 分 为 前 台 与 后 台 两 部 分 来 实现 ， 前 
台 用 于 让 用 户 输入 基本 信息 ， 后 台 则 用 于 将 用 户 信息 添加 到 用 户 表 中 。 这 里 将 前 台 与 后 台 进 行 了 
整合 ， 其 具体 内 容 如 下 : 
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以 上 代码 在 实现 用 户 注册 时 ， 分 别 对 前 台 与 后 台 进 行 了 整合 。 在 后 台 处 理 时 需要 注意 两 点 ， 
第 一 要 将 用 户 输入 的 密码 进行 md50 加 密 ; 第 二 还 要 判断 是 否 存在 同名 用 户 ， 如 果 存 在 则 给 出 提 
示 ; 如 果 不 存在 才能 执行 插入 记录 操作 。 

将 以 上 代码 保存 为 reg.php， 注 册 模 块 就 创建 完毕 ， 执 行 该 代码 的 结果 如 图 19.4 所 示 。 
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P|: hapansreg op - OX os 
Ir 


mini 商 城 系统 注册 程序 














图 19.4 注册 模块 执行 结果 


在 图 19.4 中 输入 注册 用 户 所 要 求 的 : 用 户 名 、 密 码 、 邮 箱 等 必要 信息 ， 单 击 注册 按钮 即 可 
完成 注册 。 注 册 完 成 的 结果 如 图 19.5 所 示 。 


oe) @ hapynz7ooalsareep - OX 0 
Ir | 


成 功 注册 用 户 ，guest 
点 这 里 登录 





19.5 ”完成 注册 


19.3.2 ”登录 模块 


使 用 者 在 成 功 注册 用 户 之 后 并 不 能 进入 系统 ， 还 需要 经 过 登录 才 可 以 。 所 以 登录 模块 也 是 用 
户 进入 系统 的 一 个 前 提 。 与 注册 模块 类 似 ， 登 录 模 块 也 由 前 台 与 后 台 两 部 分 组 成 。 前 台 让 用 户 输 
入 用 户 名 密码 及 Cookie 保存 时 间 ; 后 台 将 用 户 输入 信息 与 库存 信息 进行 比 对 ， 如 果 存 在 相应 的 
用 户 则 设 定 Cookie 并 进入 系统 。 具 体内 容 如 下 : 
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以 上 代码 在 处 理 用 户 登 录 时 ， 首 先 对 用 户 输入 的 密码 进行 md50 处 理 ， 然 后 通过 相应 的 SQL 
判断 是 否 存在 相应 用 户 并 且 用 户 所 输入 的 密码 也 是 正确 的 。 如 果 存在 ， 则 设 定 Cookie 并 跳 转 到 
显示 模块 的 首页 面 ; 如 果 不 存在 则 给 出 提示 ， 并 返回 到 输入 页 面 再 次 输入 。 

将 以 上 代码 保存 为 login.php， 登 录 模 块 也 创建 完毕 。 运 行 该 代码 ， 其 结果 如 图 19.6 所 示 。 


四 -|@ hapyniz7oouitogp ~ OX 
[ED 


mini 商 城 系统 登录 程序 























19.6 ”登录 模块 执行 结果 
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在 图 19.6 的 界面 中 ， 输 入 用 户 名 、 密 码 以 及 选择 登录 有 效 期 即 可 进行 登录 ， 如 果 输 入 用 户 
名 或 者 密码 错误 ， 将 会 出 现 如 图 19.7 所 示 的 提示 。 


"| 区 3 





Ct hpy2700nsnog Pp > OX oo 
[em | 
不 存在 指定 用 户 
或 者 输入 的 用 户 名 或 者 密码 错误 ! 


两 秒 后 返回 重新 输入 


19.7 用户 名 或 者 密码 错误 结果 


如 果 用 户 名 或 者 密码 错误 ， 会 给 出 用 户 提示 ， 并 自动 返回 登录 界面 重新 输入 ; 如 果 输 入 用 户 
密码 正确 ， 则 会 自动 跳 转 到 显示 模块 。 


19.4 量 示 模块 


19.4.1” 头 部 模块 


头 部 模块 是 一 个 特殊 的 模块 ， 该 模块 显示 标题 及 登录 用 户 的 信息 〈 在 用 户 已 经 登录 时 ) 供 其 
他 显示 模块 调用 。 使 用 头 部 模块 可 以 使 所 有 的 显示 模块 看 起 来 风格 一 致 ， 而 且 都 具有 共同 的 内 
容 。 该 模块 具体 内 容 如 下 : 
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头 部 模块 的 主要 功能 是 在 用 户 未 登录 时 显示 一 个 登录 表单 ， 并 将 表单 的 action 指向 login.php 
以 实现 用 户 登 录 。 而 在 用 户 已 经 登录 时 ， 显 示 查 看 登录 用 户 信息 及 退出 登录 的 超 链接 。 将 以 上 代 
码 保存 为 headerphp， 以 便 显示 模块 调用 。 其 执行 结果 如 图 19.8 所 示 。 





PHP+MySQL 网 站 开发 


| < 
〖 志 仿 ©@ htpy1127.0.0/18/headerphp p>- 赃 @Xn 0 


@127001 x pm| 


mini 商 城 系统 显示 页 面 








[尚未 登录 , 用 户 名 ”密码 有 效 期 不 全- [型 | 








图 19.8 ” 头 部 模块 执行 结果 


19.4.2 ”核心 显示 模块 


显示 模块 是 购物 网 站 的 核心 模块 ， 用 户 通过 显示 模块 才能 查看 到 所 有 的 类 别 信息 、 某 一 类 别 
信息 及 指定 商品 的 详细 信息 等 ;而 且 在 显示 商品 详细 信息 的 显示 模块 中 还 提供 了 购物 车 的 接口 ， 
用 户 只 有 通过 该 接口 才能 添加 购物 车 。 本 章 所 介绍 的 购物 网 站 中 的 显示 模块 由 三 部 分 组 成 ， 分 别 
为 首页 显示 模块 、 类 别 显示 模块 及 商品 显示 模块 等 。 下 面 分 别 介绍 这 三 种 显示 模块 。 


1. 首页 显示 模块 
首页 显示 模块 用 于 显示 当前 系统 中 所 有 已 经 存在 的 商品 类 别 的 信息 ， 其 具体 内 容 如 下 : 
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以 上 代码 通过 遍历 所 有 商品 类 别 ， 并 对 结果 进行 判断 。 如 果 不 存在 记录 ， 则 输出 无 记录 的 提 
示 ; 如 果 存 在 记录 ， 则 分 别 给 以 显示 。 这 里 要 注意 其 中 的 显示 方式 是 采用 每 行 3 个 的 方式 。 将 以 
上 代码 保存 为 show.php， 执 行 该 代码 其 结果 如 图 19.9 所 示 。 


PB EY © pyar0onns/shouphe Pp- 人 OX 0 
[em | 


mini 商 城 系统 显示 页 面 
尚未 登录 ， 用 户 名 密码 有 效 期 不 保存 ~ 








EN 尚 无 类 别 尚 无 类 别 








图 19.9 首页 显示 模块 执行 结果 


2. 类 别 显 示 模块 


与 首页 显示 模块 不 同 ， 类 别 显 示 模 块 仅 显示 属于 某 一 类 别 的 所 有 商品 ， 但 二 者 的 显示 方式 基 
本 相同 ， 均 是 使 用 每 行 三 列 的 显示 方式 。 其 具体 内 容 如 下 : 


363 








PHP+MySQL 网 站 开发 从 零 开始 学 视频 教学 版 ) ) 





〖 第 19 章 使 用 PHP+MySQL 构建 在 线 购物 网 站 








以 上 代码 首先 判断 有 无 指定 的 ID， 如 果 没 有 ， 则 给 出 提示 并 重 定向 到 显示 首页 。 如 果 存 在 
相应 ID， 则 显示 商品 表 中 属于 该 类 别 的 商品 。 将 以 上 代码 保存 为 show_type.php， 执 行 该 代码 ， 
其 结果 如 图 19.10 所 示 。 


| 由 -|@ hapyaz7ooyleshowspephpid-1 D> BO Xr 0 
| 
mini 商 城 系统 显示 页 面 


尚未 登录 , 用户 名 密码 有 效 央 不 看] 





图 19.10 类 别 模块 执行 结果 


3. 商品 显示 模块 


商品 模块 用 于 显示 指定 商品 的 详细 信息 ， 首 先 需 要 对 ID 进行 判断 ， 然 后 根据 提供 的 ID 显 
示 指 定 商品 内 容 。 其 具体 内 容 如 下 : 
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以 上 代码 中 不 仅 显 示 指 定 商品 的 相关 信息 ， 同 时 还 判断 用 户 是 否 登录 。 如 果 用 户 已 经 登录 则 
显示 一 个 “把 商品 加 入 购物 车 ”按钮 ， 通 过 该 按钮 将 实现 将 当前 查看 的 商品 加 入 购物 车 的 目的 。 
将 以 上 代码 保存 为 show_goods.php， 执 行 该 代码 ， 其 结果 如 图 19.11 所 示 。 
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i | WH) @ htpy27.0.021n8/show goods.phprid= P OX Go 
rr 


mini 商 城 系统 显示 页 面 























图 19.11 显示 商品 模块 执行 结果 


19.4.3 ”购物 车 模块 


当 登 录用 户 使 用 show_goods.php 查看 指定 商品 的 详细 信息 时 ， 会 用 到 添加 购物 车 的 功能 ， 
该 功能 通过 一 个 JS 文件 mycatjs 实现 ， 其 具体 内 容 如 下 : 
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以 上 该 代码 通过 JavaScript 操作 相应 的 Cookie 值 实现 购物 车 的 功能 。 将 以 上 代码 保存 为 
mycatjs 以 便 在 需要 调用 相应 购物 车 功能 时 使 用 该 JS 文件。 


19.4.4 查看 并 统计 购物 车 模块 


仅 能 将 指定 商品 添加 到 购物 车 还 不 行 ， 还 需要 提供 查看 购物 车 并 生成 订单 的 功能 模块 。 该 模 
块 通过 读 取 指定 Cookie 值 来 查看 用 户 购物 车 ， 并 在 用 户 单 击 “ 生 成 订单 ”按钮 时 生成 相应 的 订 
单 记录 。 其 内 容 如 下 : 
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以 上 代码 在 前 台 查 看 购物 车 中 所 有 选 定 的 商品 信息 ， 并 按 用 户 选择 内 容 提交 到 后 台 。 后 台 则 
按照 用 户 选 择 的 内 容 生 成 相应 的 订单 并 给 出 提示 。 注 意 因为 是 首次 添加 的 订单 ， 所 以 其 状态 全 都 
为 未 经 处 理 〈sale_ state 值 为 0) 。 将 以 上 代码 保存 为 show_catphp， 如 果 用 户 在 如 图 19.11 所 示 
显示 商品 信息 页 面 中 单 击 “ 把 该 商品 放 入 购物 车 ”按钮 ， 即 可 弹出 页 面 如 图 19.12 所 示 。 











图 19.12 查看 当前 购物 车 模块 
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1 日 .5 用 户 模块 


19.2 节 介 绍 了 实现 整个 在 线 购物 网 站 所 要 求 的 全 部 功能 模块 。 按 其 功能 可 划分 为 注册 登录 相 
关 、 查 看 商品 相关 、 查 看 用 户 信息 相 关 、 添 加 与 编辑 类 别 、 添 加 与 编辑 商品 、 处 理 订 单 及 退出 登 
录 等 。 本 节 来 实际 运行 这 几 个 功能 模块 ， 查 看 其 是 否 能 够 按照 既定 的 规划 方案 执行 。 


19.5.1 显示 用 户 信息 模块 


显示 用 户 信息 在 头 部 模块 headerphp 中 提供 了 接口 ， 注 册 用 户 登录 后 ， 单 击 其 中 显示 的 用 户 
名 即 可 跳 转 到 显示 用 户 信息 模块 ， 该 模块 不 仅 显示 用 户 信息 ， 还 在 其 中 提供 了 修改 密码 、 查 看 我 
的 历史 订单 ， 以 及 为 管理 员 提 供 的 处 理 订单 等 模块 的 链接 。 具 体内 容 如 下 : 
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以 上 代码 首先 判断 用 户 的 登录 状态 ， 如 果 未 登录 则 给 出 登录 链接 ， 如 果 用 户 已 经 登录 则 通过 
登录 用 户 名 在 用 户 表 中 查询 其 所 有 注册 信息 并 予以 显示 。 将 以 上 代码 保存 为 userinfo.php， 执 行 
该 代码 ， 其 结果 如 图 19.13 所 示 。 


四 -|o nyizootisp - BOX 0 
[Em 


用 户 信息 查看 页 面 











图 19.13 ”查看 用 户 信息 页 面 


19.5.2 ”修改 用 户 密码 模块 


由 于 本 章 所 介绍 的 购物 网 站 用 户 表 字 段 较 少 ， 内 容 较为 单一 ， 所 以 仅 提供 修改 密码 模块 。 如 
果 用 户 需 要 ， 也 可 以 扩充 用 户 表 字 段 ， 根 据 相同 原理 创建 相应 的 修改 用 户 注册 信息 模块 。 修 改 用 
户 密码 模块 详细 情况 如 下 : 


373 








PHP+MySQL 网 站 开发 从 零 开 始 学 〈 视 频 教 学 版 ) 】 




















PHP+MySQL 构建 在 线 购物 网 站 





PHP+MySQL 网 站 开发 从 零 开始 学 〈 视 频 教学 版 ) 





修改 密码 项 同样 需要 用 户 登 录 才 能 进行 操作 ， 所 以 修改 用 户 密码 模块 首先 仍 是 判断 用 户 是 否 
登录 。 并 在 确认 用 户 登 录 后 ， 判 断 是 否 有 提交 的 内 容 ， 如 果 没有 则 显示 前 台 供用 户 输入 相关 内 
容 ; 如 果 已 经 提交 则 进入 后 台 进行 处 理 。 将 以 上 代码 保存 为 e_pass.php， 执 行 该 代码 ， 其 结果 如 
图 19.14 所 示 。 


四 .Ge yzoowp - OX 
CE 


修改 用 户 密码 页 面 








图 19.14 ”修改 用 户 密码 页 面 执行 结果 


查看 图 19.14 的 执行 结果 可 以 看 到 ， 用 户 需 要 输入 原始 密码 、 新 密码 及 重复 输入 新 密码 ， 即 
可 完成 对 密码 的 修改 。 


19.5.3 ”查看 用 户 历 史 订 单 模块 


注册 用 户 登 录 后 除了 能 够 查看 注册 信息 、 修 改 密码 以 外 ， 还 能 查看 当前 登录 用 户 的 历史 订 
单 。 查 看 历史 订单 能 让 用 户 了 解 自己 在 系统 中 的 采购 情况 及 订单 处 理 情况 。 历 史 订单 模块 的 具体 
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以 上 代码 通过 指定 的 登录 用 户 名 从 订单 表 中 遍历 所 有 属于 登录 用 户 的 订单 并 显示 。 因 为 订单 
表 中 仅 保 存 了 商品 ID 并 没有 保存 商品 名 称 ， 所 以 还 需要 再 进行 一 次 查询 以 获取 相应 ID 的 商品 
名 称 。 将 以 上 代码 保存 为 show_sale.php， 执 行 该 代码 ， 其 结果 如 图 19.15 所 示 。 


Oe wm - ao x er 
em 
查看 用 户 历史 订单 


[首页 坦 丰 用 
尚 没 有 用 户 user 的 订单 





图 19.15 查看 用 户 历史 订单 


由 于 当前 用 户 并 没有 下 订单 ， 所 以 显示 没有 订单 内 容 的 信息 。 如 果 用 户 已 经 生成 过 订单 ， 则 
其 执行 结果 将 会 如 图 19.16 所 示 。 


OI own - ox 
[em 


查看 用 户 历史 订单 











19.16 查看 用 户 历史 订单 信息 
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1 日 .6 管理 模块 


19.2 节 介 绍 了 实现 整个 在 线 购物 网 站 所 要 求 的 全 部 功能 模块 。 按 其 功能 可 划分 为 注册 登录 相 
关 、 碍 看 商品 相关 、 查 看 用 户 信息 相关 、 添 加 与 编辑 类 别 、 添 加 与 编辑 商品 、 处 理 订 单 及 退出 登 
录 等 。 本 节 来 实际 运行 这 几 个 功能 模块 ， 查 看 其 是 否 能 够 按照 既定 的 规划 方案 执行 。 


19.6.1 处理 订单 模块 


如 果 判 断 登 录用 户 为 管理 员 ， 则 其 拥有 处 理 订 单 的 权利 。 在 真实 的 大 型 购物 网 站 中 处 理 订 单 
通常 意味 着 卖家 收 到 了 买 家 通过 支付 手段 所 支付 的 货款 。 而 这 些 要 涉及 网 上 银行 接口 或 者 支付 宝 
接口 等 内 容 ， 这 里 不 再 涉及 。 这 里 所 实现 的 功能 是 : 假设 卖家 收 到 了 货款 ， 即 将 订单 状态 改 为 已 
处 理 。 其 具体 内 容 如 下 : 
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由 于 处 理 订单 是 只 有 管理 员 才 拥有 的 权限 ， 所 以 以 上 代码 不 仅 判断 用 户 是 否 登录 还 要 判断 登 
录用 户 是 否 为 管理 员 。 然 后 根据 提供 的 订单 ID 将 其 状态 更 新 为 已 经 处 理 即 可 。 将 以 上 代码 保存 
为 e_sale.php， 执 行 该 代码 ， 其 结果 如 图 19.17 所 示 。 


a: @ npnzrooins,o - Box os 
[em 


管理 所 有 未 处 理 历史 订单 


dla 
user | 小 米 5 1900 2009 和 月 队 | 
2 本 四 天 pa 


图 19.17 处 理 订单 页 面 执行 结果 


此 时 ， 如 果 管 理 员 单 击 图 19.17 中 每 一 项 未 处 理 订单 后 面 的 处 理 链接 将 会 对 指定 的 订单 进入 
处 理 ， 并 在 处 理 完 之 后 ， 自 动 返回 管理 未 处 理 历 史 订 单 页 面 。 








19.6.2 ”添加 类 别 模块 


本 节 及 下 面 19.6.3 节 、19.6.4 节 、19.6.5 节 将 分 别 介绍 4 个 功能 相对 独立 的 管理 模块 ， 分 别 
为 添加 类 别 模块 、 编 辑 类 别 模块 、 添 加 商品 模块 和 编辑 商品 模块 。 执 行 这 些 操作 与 处 理 订单 一 样 
也 需要 管理 员 身 份 。 本 系统 假设 商品 及 类 别 在 添加 后 不 能 删除 ， 所 以 不 再 提供 商品 及 类 别 的 删除 
模块 ， 有 兴趣 的 读者 在 学 完 本 书后 完全 有 能 力 自己 创建 相应 的 删除 模块 。 

添加 类 别 模块 由 前 台 与 后 台 两 部 分 组 成 ， 前 台 供 管理 员 输 入 类 别 相关 信息 ， 后 台 负 责 将 相关 
信息 插入 到 类 别 表 中 。 具 体内 容 如 下 : 
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以 上 代码 在 插入 类 别 记 录 时 ， 还 判断 了 是 否 存在 同名 类 别 ， 如 果 存 在 ， 则 予以 提示 ; 如 果 不 
存在 ， 才 执行 插入 操作 ， 这 一 点 要 注意 。 将 以 上 代码 保存 为 add_type.php， 执 行 该 代码 ， 其 结果 
如 图 19.18 所 示 。 





PHP+MySQL 网 站 开发 


Oe wu - a o x rs 
Ez 


mini 商 城 系 统 添加 类 别 


Him 类 2 称 | | 
添加 类 别 介绍 








图 19.18 ”添加 类 别 页 面 执行 结果 


在 图 19.18 所 示 页 面 中 输入 商品 类 别名 称 与 商品 介绍 ， 单 击 “ 添 加 ”按钮 ， 即 可 对 相应 商品 
类 别 进行 添加 。 


19.6.3 ”编辑 类 别 模块 


类 别 在 添加 之 后 并 不 是 一 成 不 变 的 ， 有 时 根据 实际 情况 需要 对 类 别 的 内 容 进行 修改 ， 这 时 就 
需要 编辑 类 别 模块 。 与 添加 类 别 相 类 似 ， 编 辑 类 别 也 是 需要 以 管理 员 身 份 进行 登录 才能 进行 的 操 
作 。 另 外 ， 本 章 所 介绍 的 购物 网 站 商品 类 别 表 内 容 也 较为 简单 ， 所 以 仅 能 对 类 别 介绍 进行 修改 。 
其 具体 内 容 如 下 : 
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编辑 类 别 模块 分 三 步 ， 第 一 步 在 没有 提供 指定 类 别 ID 时 显示 所 有 类 别 ， 第 二 步 在 有 类 别 ID 
时 先 显示 前 台 供 用 户 输入 内 容 ， 第 三 步 在 用 户 提交 类 别 内 容 时 ， 用 新 的 内 容 更 新 指定 类 别 。 注 意 
这 里 仅 对 类 别 的 介绍 进行 了 更 新 。 将 以 上 代码 保存 为 e_type.php， 执 行 该 代码 ， 其 结果 如 图 
19.19 所 示 。 


四 -|@ ntpynz7ootiep - OX 
ED 
管理 所 有 类 别 
| 编号 “| 类别 名称。 _ | 类 别 介绍 
1 | 手机 各 种 手机 
2 平板 电脑 | 各 种 平板 电脑 











图 19.19 管理 所 有 类 别 


从 图 19.19 的 执行 结果 可 以 看 到 ， 此 时 给 出 了 所 有 的 类 别 供 管理 员 进 行 修改 ， 管 理 员 单 击 每 
个 类 别 后 面 的 “修改 ”链接 即 可 打开 对 类 别 介绍 进行 修改 的 页 面 ， 如 图 19.20 所 示 。 


a) :hepa2roons, po - OX 0 
[rm | 
| i 
E 1 
手机 








各 种 手机 | 
| 

















19.20 修改 具体 类 别 执行 结果 
在 图 19.20 所 示 的 界面 中 可 以 对 类 别 的 介绍 进行 修改 。 


19.6.4 添加 商品 模块 
与 类 别 一 样 ， 商 品 也 需要 有 专门 的 添加 模块 。 在 添加 商品 时 需要 注意 ， 除 了 将 管理 员 输入 商 
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品 信息 插入 表 中 之 外 ， 还 需要 同步 更 新 相应 的 商品 类 别 的 数量 。 这 样 才 能 保证 商品 类 别 数 与 其 所 
属 的 商品 存货 数量 保持 一 致 。 添 加 商品 模块 具体 内 容 如 下 : 
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这 里 需要 注意 的 是 ， 添 加 商品 时 ， 商 品 所 属 类 别 的 增 量 即 为 所 添加 的 商品 存货 量 。 将 以 上 代 
码 保存 为 add_goods.php， 执 行 该 代码 ， 其 结果 如 图 19.21 所 示 。 


[3 
em 


mini 商 城 系 统 添加 商品 


| 添加 商品 名 称 
商品 所 属 类 别 
| 添加 商品 价格 
| 添加 商品 数量 




















图 19.21 添加 商品 模块 执行 结果 


19.6.5 ”编辑 商品 模块 
与 类 别 一 样 ， 商 品 在 添加 之 后 出 于 某 种 需要 也 要 对 其 内 容 进行 调整 。 最 为 常用 的 是 当 某 种 商 
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品 存货 量 为 0 时 需要 重新 上 架 ， 并 要 更 新 其 存货 数量 。 其 他 的 商品 信息 也 可 以 在 该 功能 模块 中 被 
改变 。 详 细 内 容 如 下 : 











PHP+MySQL 网 站 天 





发 从 零 天 





ET 

















PHP+MySQL 构建 在 线 购物 网 站 





PHP+MySQL 网 站 开发 从 零 开始 学 〈 视 频 教 学 版 ) 





注意 以 上 代码 在 修改 商品 数量 时 ， 还 特别 同步 更 新 了 商品 所 属 类 别 的 数量 。 注 意 这 里 的 类 别 
数量 变动 为 类 别 原 数量 加 商品 新 数量 相 比 商品 原 数量 的 增 量 。 比 如 ， 某 一 商品 原始 数量 为 0， 其 
所 属 类 别 数 量 为 8( 因 为 一 个 商品 类 别 中 不 一 定 只 有 一 种 商品 ); 进行 修改 后 ， 商 品 数量 变 为 
5， 则 类 别 数量 就 为 《8+ (5-0) ) 三 13。 这 样 可 以 保持 商品 数量 与 其 所 属 类 别 保持 一 致 。 

将 以 上 代码 保存 为 e_goods.php， 执 行 该 代码 ， 其 结果 如 图 19.22 所 示 。 


[Oo wn - ao x ee 
[rr 


管理 所 有 商品 





医 同 B 了 信人 二 7 细作 











1 路 米 5 |1 soo 引水 这 可 机 14 








图 19.22 编辑 商品 模块 


查看 图 19.22 的 执行 结果 可 以 看 出 ， 此 时 列 出 了 所 有 的 商品 供 管理 员 进行 编辑 ， 单 击 相应 商 
品 后 面 的 修改 链接 即 可 打开 如 图 19.23 所 示 的 修改 界面 。 
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I |W Gwe o - ox No 
[emo 


商品 : 小 米 5 的 内 容 








商品 编号 ， 
商品 名 称 ， 
商品 售 价 : 
商品 数量 ， 
商品 介绍 : 

















EE 








图 19.23 编辑 商品 模块 I 


在 图 19.23 所 示 界 面 中 可 以 对 商品 的 有 关 信息 进行 修改 ， 修 改 完成 之 后 单 击 “ 提 交 修改 ” 按 
钮 即 可 完成 修改 过 程 。 


19.6.6 ”退出 登录 模块 


以 上 各 节 已 经 介绍 了 整个 商城 所 需要 的 全 部 功能 。 除 此 之 外 还 需要 一 个 简单 的 模块 ， 即 退出 
登录 模块 。 使 用 该 模块 可 以 方便 用 户 退 出 购物 网 站 ， 这 样 可 以 有 效 保护 用 户 的 信息 安全 。 退 出 登 
录 模 块 功能 相当 简单 ， 只 需要 简单 清除 相应 Cookie 并 转向 即 可 。 其 具体 内 容 如 以 下 代码 所 示 : 





执行 以 上 代码 将 清空 用 户 的 登录 Cookie 并 跳 转 到 查看 首页 。 将 以 上 代码 保存 为 quitphp， 退 
出 登录 模块 也 创建 完毕 。 
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